【驗證碼逆向專欄】某驗“初代”滑塊驗證碼逆向分析

K哥爬蟲發表於2023-02-03

00

宣告

本文章中所有內容僅供學習交流,抓包內容、敏感網址、資料介面均已做脫敏處理,嚴禁用於商業用途和非法用途,否則由此產生的一切後果均與作者無關,若有侵權,請聯絡我立即刪除!

本文章未經許可禁止轉載,禁止任何修改後二次傳播,擅自使用本文講解的技術而導致的任何意外,作者均不負責,若有侵權,請在公眾號【K哥爬蟲】聯絡作者立即刪除!

逆向目標

  • 目標:某驗”初代“滑塊驗證碼,實為二代離線模式,validate 引數逆向,底圖獲取及還原
  • 主頁:aHR0cHM6Ly9mdy5zY2pnai5zaC5nb3YuY24vbm90aWNlc2gvaG9tZQ==
  • 加密演算法:MD5

前世溯源

眾所周知某驗是首家 ”行為式驗證“ 安全技術服務提供商,其摒棄了扭曲複雜的字元圖片驗證碼,大大增強了使用者的體驗感。某驗最初代的驗證碼,是在2012年年底完成的,產品還在內測時,最早的種子使用者,大都來自於創始人吳淵母校武漢大學的珞珈山水BBS站:

01

2014年年中,極驗正式開放服務,武漢本土網際網路企業尤其是遊戲類企業給予了“力挺”。武漢265G是全國最大的網頁遊戲資訊網站,率先使用了極驗“點一下拖一下就能完成驗證”的全新驗證方式。後來,透過口口相傳,武漢17173、電玩巴士等遊戲入口網站,也陸續使用其產品。“行為式驗證”上線後從遊戲行業開始,逐步取代網際網路上各種形式的傳統驗證碼,推廣到全國各地。

下圖為早年市面上的初代產品,時過境遷,是否還存在網站使用無從得知,如果有了解的歡迎私聊 K 哥:

02

抓包情況

真正的初代產品無從分析,上一篇 K 哥寫的為二代滑塊線上模式,可以閱讀:【驗證碼逆向專欄】某驗二代滑塊驗證碼逆向分析,本案例為二代滑塊離線模式分析,與常規的某驗產品還是有較大區別的,主頁輸入企業名稱點選搜尋會彈出滑塊驗證碼,register 介面返回熟悉的 challengegt 引數:

03

如果對某驗其他產品瞭解的話,圖片下載路徑及加密引數是透過類似 get.php 介面返回的,並且 validate 引數是校驗 w 引數後得到的,而當前過掉滑塊後,validate 引數直接生成並完成校驗了,所有流程都是在本地直接執行的:

04

  • validate 介面:校驗滑塊是否透過;
  • ent_info_list 介面:校驗 session.tokenvalidate ,未透過則和一開始的 home 介面返回內容一致,透過則會多出相關企業資訊。

逆向分析

主頁搜尋生成驗證碼後,從驗證介面 validate 處跟棧,跟進到 u1G.<computed> 中:

05

格式化,進入到 geetest.0.0.0.js 檔案的第 5689 行,該行打下斷點滑動滑塊即會斷住,可以看到 H2Y 為 fail,此時已經校驗完成,並顯示失敗了:

06

繼續向上跟棧,在第 3273 行打下斷點,這裡即為校驗的位置:

07

關鍵部分如下:

W1Y[f2Z.S3C(60)](m1Y, f1G[f2Z.t3C(537)](f2Z.t3C(551), R1Y[f2Z.S3C(278)])[f2Z.t3C(155)]() - f1G[f2Z.S3C(537)](f2Z.S3C(633), R1Y[f2Z.S3C(278)]), R1Y)

於控制檯列印一下,初步推測 W1Y[f2Z.S3C(60)] 方法校驗了滑動距離、滑動時間及其他的一些引數:

08

跟進 W1Y[f2Z.S3C(60)],跳轉到 offline.6.0.0.js 檔案中,格式化後,打斷點會發現這裡就是 validate 引數的加密位置:

09

validate: b.A(c, e.d.challenge) + "_" + b.A(a.b("rand0", e.c), e.d.challenge) + "_" + b.A(a.b("rand1", e.c), e.d.challenge)

c 為滑動距離,e.d.challengechallenge 引數的值,e.c 為13位時間戳,加密方式為 b.Aa.b,扣下來即可,不過經測試 a.b("rand0", e.c) 即 d,a.b("rand1", e.c) 為 e 的值,分別定義在下圖第 173、174 行,分析過程中發現採集了滑塊軌跡,不過並沒有校驗,validate 引數分析完了,那圖片路徑在哪呢,就在這部分的上面,f、g 經過了 MD5 加密,同樣直接扣下來:

10

不過直接這樣下載的圖片是亂序的,還原始碼同三代滑塊及二代滑塊線上模式基本一致,寬度需要改動,可參考 【驗證碼逆向專欄】某驗三代滑塊驗證碼逆向分析

11

還原後如下:

12

結果驗證

滑塊驗證:

13

搜尋結果驗證,需要先從 home 介面中獲取到 session.token,再加上 validate 等引數即可:

14

相關文章