手上有一臺上古時代的tp-link,獲取ip沒問題,可是速度太慢,因而研究了水星mac1200R.javascript
經過Firebug研究登錄能夠知道java
首先登錄的時候,須要將密碼編碼之後以json形式傳給路由器,而後會響應你一個stok做爲構造url請求的安全令牌python
下面是請求之後獲取的stokjson
而後,除了加載必要的頁面之外,全部的通訊都是經過js代碼xhr請求交換json數據來填充頁面的。瀏覽器
好比咱們想知道的wan口信息,能夠請求安全
http://192.168.4.1/stok=4f0bd18f8e0b75f6c27f153d63818153/dsapp
而後請求參數爲curl
{"network":{"name":"wan_status"},"method":"get"}
請求之後得到的響應報文爲:函數
{ "network": { "wan_status": { "down_speed": 0, "up_speed": 0, "ipaddr": "223.243.12.94", "link_status" : 1, "phy_status": 1, "error_code": 0, "proto": "pppoe", "pri_dns": "61.132.163.68", "gateway": "223 .243.0.1", "up_time": 152098, "snd_dns": "202.102.213.68", "netmask": "255.255.255.255" } }, "error_code" : 0 }
至此,大致的思路就是:工具
一、首先構造post請求,得到stok安全令牌
二、經過安全令牌、json請求wan口地址
import urllib.request import json #讀取內容的函數 def get_data(url,data=None): headers = {#"User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:47.0) Gecko/20100101 Firefox/47.0", #"Referer": "http://192.168.4.1/", #"Accept": "application/json, text/javascript, */*; q=0.01", #"X-Requested-With": "XMLHttpRequest", #"Content-Type": "application/json; charset=UTF-8" } #水星的路由器對請求頭驗證不是很嚴格,我把這些都關閉了彷佛也一切正常,若是大家有須要本身關閉註釋 data = json.dumps(data).encode("utf-8") #data = urllib.parse.urlencode(data) #data = data.encode("utf-8") req = urllib.request.Request(url,data,headers) response = urllib.request.urlopen(req) data = response.read() response.close() return data #獲取令牌 url = "http://192.168.4.1/" #路由器ip paras = {"method":"do","login":{"password":"AY2X56xURTefwww"}} #密碼具體如何加密的不太清楚,我是直接在瀏覽器上看的 data= get_data(url,paras).decode() stok = json.loads(data).get("stok") #經過stok構造url url = "http://192.168.4.1/stok="+stok+"/ds" #請求參數 js = {"protocol":{"name":["pppoe","wan"]},"network":{"name":"wan_status"},"method":"get"} data = get_data(url,js) #解析獲取的數據,取得ip ip =json.loads(data.decode()).get("network").get("wan_status").get("ipaddr")
各廠商路由器型號各不相同,沒有通用的方法,這個只能針對水星路由器,其餘狀況須要本身分析,若是dd-wrt應該只須要正則就能夠,由於他們登錄以前就能夠看wan ip。
其實firebugs生成的curl應該更簡單,不過沒測試過是否可行,固然你也能夠本身封裝一個適合本身的類curl工具