PHP基於curl後台遠端登入正方教務系統的方法

2022-09-29 22:21:16 字數 892 閱讀 5708

從去年想這個事情怎麼解決,今年終於算是把他搞清楚了,但驗證碼必須要填。

如果你能像360搶票哪有自動識別驗證碼,那就沒事了。廢話不多扯了。回歸正題

這裡要用curl。

設計思路:先登入頁面獲取cookies,然後拿著cdngwiookies找伺服器要驗證碼。最後提供伺服器需要的全部資訊。

(這種思維是完全模擬遊覽器訪問頁面,根本區別出來是人還機器)

public function index()

訪問正方教務系統的首頁,第一獲取頁面中的html,第二是獲取cookies。

其他的就想問?獲取html有啥用?

如果你細心觀察教務系統首頁的html的話,你會發現裡面有很多隱藏字段,而這些欄位又是變化的。

所以你乾脆把html都獲取然後解析,然後把需要的字段都桃出來

html結構

看到沒有,那麼的隱藏字段,都是提交資料的必須,而且不能多。

頁面效果

接下來我要將乙個最重要的問題,怎麼獲取驗證碼?

開始我想直接

不就行了?這樣驗證碼雖然是出來,但這個驗證碼不屬於你,所以在你存遠端登入時候,都會告訴你,驗證碼錯誤

那怎麼獲取屬於自己的驗證碼呢?這時候,自然想到的是cookies。

伺服器是怎麼區分遊覽器請求是不是同乙個人,就看cookies裡面的sessionid了

這樣。你拿著你在首頁獲取到的cookies,再找伺服器要你的驗證碼,它會給錯?

public function getimg()

然後再在其他頁面呼叫這個方法,你就可以獲取到驗證碼。

curl的php請求跟你遊覽器發出的php屬於兩個不同的執行緒,所以,他們的cookies是不同共用的。

這樣你就可以登入了,但不要以為這樣登入了,你可以操作全部功能了,那你就想錯了。還有乙個很小的細節。。

PHP獲取Cookie模擬登入CURL

分享到 17 要提取google搜尋的部分資料,發現google對於軟體抓取它的資料遮蔽的厲害,以前偽造下 user agent就可以抓資料,但是現在卻不行了。利用抓包資料發現,google判斷了cookies,當你沒有cookies的時候,直接返回30 要提取google搜尋的部分資料,發現goo...

PHP獲取Cookie模擬登入CURL

要提取google搜尋的部分資料,發現google對於軟體抓取它的資料遮蔽的厲害,以前偽造下 user agent 就可以抓資料,但是現在卻不行了。利用抓包資料發現,google 判斷了 cookies,當你沒有cookies的時候,直接 返回 302 跳轉,而且是連續幾十個302跳轉,根本抓不了資...

php使用curl實現模擬登入例項

function login post url,cookie,post function get content url,cookie post array username 使用者名稱 password 密碼 usecookie 0 action login submit 1,cookie coo...