抓包獲得東北大學的課程表,考試成績

来源:http://www.cnblogs.com/xfangs/archive/2016/03/02/5234451.html
-Advertisement-
Play Games

假期本想要嘗試做一些不同的事,卻一直荒廢,偶然看到了幕課,頓時後悔,再借我一個假期,一定在幕課上認真學習。比自己看書效率高很多啊! 於是反正無聊,用了一個晚上瞭解了一下python(僅限於瞭解),總想做點啥有意思的,想來想去還是和抓包聯繫上了。 鑒於Wireshark我是真不怎麼會用,這次抓包用的軟


假期本想要嘗試做一些不同的事,卻一直荒廢,偶然看到了幕課,頓時後悔,再借我一個假期,一定在幕課上認真學習。比自己看書效率高很多啊!

於是反正無聊,用了一個晚上瞭解了一下python(僅限於瞭解),總想做點啥有意思的,想來想去還是和抓包聯繫上了。

鑒於Wireshark我是真不怎麼會用,這次抓包用的軟體為Charles。

Charles是Mac上比較好用的抓包軟體,操作真的是十分簡單,媽媽再也不用擔心我不會抓包了。同時手機上的流量也是可以抓取的,將手機與電腦連在同一區域網,手動設置Wi-Fi代理,地址為電腦的內網IP,埠8888。太愛了!

上面啊就是地址了,能看出只是提交了 用戶名,md5加密的密碼 以及 時間。

首先先寫一個md5加密的函數來

1 def md5(str):  
2     import hashlib  
3     m = hashlib.md5()  
4     m.update(str)  
5     return m.hexdigest() 

我不會說我都是百度來的。。。

 

然後是提交時間,也就是那個token,就我目前的水準來看(準小白),這個只是用來區分用戶的,所以我果斷的取了隨機數,不過為了顯得像正經的鏈接一點,還是把時間加在了前頭。

 1 def ran():  
 2     import random  
 3     return str(random.randint(1000000000000000000, 2999999999999999999))  
 4   
 5 def tim():  
 6     import time  
 7     day = time.strftime("%Y%m%d")  
 8     now = time.strftime("%H%M%S")  
 9     return  day+now  
10 userName = '20150000'  
11 passwd = md5('20150000')  
12 token = tim()+ran()
13 url = "http://202.118.31.241:8080/api/v1/login?userName="+userName+"&passwd="+passwd+"&token"+token

 

這樣提交的鏈接就弄好了。下麵是進行網路操作,引用了urllib2。

1 def WebView(urls):  
2     import urllib2  
3     request=urllib2.Request(urls)  
4     web=urllib2.urlopen(request)  
5     return web.read().decode('gbk').encode('utf-8')  

 

同樣被我寫成了函數的形式。

根據後來操作的抓包來看,系統會返回一個時間的字元串以後的請求都是根據它來進行的。

1 Login = WebView(url)

先把咱們“製作”出來的鏈接在登陸函數里運行一下,得到返回值。

{"success":"0","errCode":"","errMsg":"","data":{"token":"201602291749112430008019436","userName":"20150000","realName":"路人甲","isTeacher":"0"}} 

上面就是返回的Login了。

我們要獲得那個token後面的數字,這個獲得的東西呢是json格式的,我們進行解析就能得到token的值。

1 import json  
2 JsonLogin = json.loads(Login)  
3 token = JsonLogin['data']['token']  
4 UrlKeBiao = "http://202.118.31.241:8080/api/v1/courseSchedule2?token="+token  

當解析過後,JsonLogin就變成了dict類型,而JsonLogin['data']是dict中的dict,最終用獲取的token值我們就能進行各種訪問了。

比如,UrlKeBiao = "http://202.118.31.241:8080/api/v1/courseSchedule2?token="+token 這是請求課表的地址

UrlKeBiao = "http://202.118.31.241:8080/api/v1/courseSchedule1?token="+token 這是成績查詢的地址

 

還有什麼空教室,創新學分,等等都可以查看了,這些內容都是json格式的,進行解析過後就能夠流暢閱讀

比如我寫的解析課程表的代碼:

 1 KeBiao = WebView(UrlKeBiao)  
 2 JsonKeBiao = json.loads(KeBiao)  
 3 print type(JsonKeBiao['data'])  
 4 print type(JsonKeBiao['data'][0])  
 5 k=0  
 6 r=0  
 7 while r!=6:  
 8     print "%-25.20s"%(JsonKeBiao['data'][k+r]['name']),  
 9     k+=6  
10     if k==42:  
11         k=0  
12         r=r+1  
13         print '\n'  

為了能正常顯示漢語,還需要加上下麵這四行。

# -*- coding: utf-8 -*  
import sys  
reload(sys)  
sys.setdefaultencoding( "utf-8" ) 

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 引入自: http://blog.csdn.net/aaronuu/article/details/7055650 List 轉換為 String數組 List<String> list = new ArrayList<String>(); list.add("a1"); list.add("a2"
  • 下載 cURL http://pan.baidu.com/s/1hqrHWkG (curl-7.39.0.tar.gz) 3.98MB 解壓: [plain] view plain copy tar zxvf curl-7.39.0.tar.gz ./configure --prefix=/usr/
  • 試可以幫助識別和解決應用程式缺陷,在本文中,作者將使用大家常用的的開發工具Eclipse來調試Java應用程式。但這裡介紹的調試方法基本都是通用的,也適用於NetBeans IDE,我們會把重點放在運行時上面。 在開始之前,推薦大家去看看Eclipse shortcuts這篇文章,它將會給你帶來很多
  • 一、java編程註意事項1.java區分大小寫2.每條語句結尾有分號3.上下級代碼註意縮進4.大括弧要成對出現5.標點符號要用英文半形(半形全形區別)二、eclipse1.eclipse是自編譯及時編譯2.java ee包含java se 三、變數 1.+表示將多段文字拼接成一句話 2.使用變數就相
  • 設置微信支付需要的4個參數APPID APPSECRET MCHID KEY在哪裡找呢 其中APPID APPSECRET為公眾號的appid和appsecret,在微信公眾平臺後臺查看 開發》基本配置》開發者ID MCHID和KEY為微信支付商戶號和API密鑰,在微信支付商戶平臺後臺查看 MCHI
  • http://blog.csdn.net/bluishglc/article/details/47909593?utm_source=tuicool&utm_medium=referral 實際工作中用到網路知識的機會並不多,雖然以前學習過,但是許久不用自然也就生疏了。最近拿到幾台雲上的虛擬機,需要
  • MyEclipse 2016基於Eclipse Mars 1 (4.5.1),除了在Eclipse基礎上做了更新之外,我們還更新了集成在MyEclipse上的第三方工具,比如STS, m2e, BIRT, Webtools, eGit等等。 Mars集成對Java的一些核心進行了改進,比如編譯器的...
  • PDO是一個“資料庫訪問抽象層”,作用是統一各種資料庫的訪問介面,與mysql和mysqli的函數庫相比,PDO讓跨資料庫的使用更具有親和力;與ADODB和MDB2相比,PDO更高效。目前而言,實現“資料庫抽象層”任重而道遠,使用PDO這樣的“資料庫訪問抽象層”是一個不錯的選擇。 PDO中包含三個預
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...