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

来源:https://www.cnblogs.com/ikdl/archive/2023/02/03/17089788.html
-Advertisement-
Play Games

聲明 本文章中所有內容僅供學習交流,抓包內容、敏感網址、數據介面均已做脫敏處理,嚴禁用於商業用途和非法用途,否則由此產生的一切後果均與作者無關,若有侵權,請聯繫我立即刪除! 本文章未經許可禁止轉載,禁止任何修改後二次傳播,擅自使用本文講解的技術而導致的任何意外,作者均不負責,若有侵權,請在公眾號【K ...


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


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

-Advertisement-
Play Games
更多相關文章
  • SpringMVC介紹-01 1.離線文檔 解壓 spring-5.3.8-dist.zip文件。 位置:spring-framework-5.3.8/docs/reference/html/web.html#spring-web 2.SpringMVC基本介紹 2.1SpringMVC特點&概述 ...
  • 1 簡介 我們進行Web API開發的時候,經常會使用Json格式的消息體,而Json格式非常靈活,不同的人會有不同的設計風格和實現,而JSON API提供了一套標準。但它並不提供直接實現。 Katharsis是JSON API的Java實現,使用它可以快速開發出Json based的Web介面,還 ...
  • Python有哪些關鍵字 Python常用的關鍵字 and, del, from, not, while, as, elif, global, or, with, assert, else, if, pass, yield, break, except, import, print, class, ...
  • 前言 前面我們已經學習了Python的基礎語法,瞭解了Python的分支結構,也就是選擇結構、迴圈結構以及函數這些具體的框架,還學習了列表、元組、字典、字元串這些Python中特有的數據結構,還用這些語法完成了一個簡單的名片管理系統。下麵我就將介紹一下Python的一些進階語法規則,為後面更複雜的編 ...
  • Map 介面與 Collection 併列存在的,用於保存具有映射關係的數據:key-value 被稱為 鍵值對 。Java集合可分為 Collection 和 Map 兩種體系。Map 中的 key 和 value 都可以是任何引用類型的數據。Map 中的 key 用 Set 集合存儲的,不允許... ...
  • 鋼鐵知識庫,一個學習python爬蟲、數據分析的知識庫。人生苦短,快用python。 使用pycharm創建python文件時候,有時候需要自動生成想要的文件頭,如何生成呢? 只需要以下幾步: 在file->settings中搜索temp,找到file and code templates->pyt ...
  • Java集合框架 每博一文案 《殺死一隻知更鳥》中有這樣一段話:“你永遠不可能真正地瞭解一個人,除非你穿上他的鞋子走來走去,站在他的角度思考問題。 可真當你走過他的路時,你連路過都覺得難過。” 世上沒有真正的感同身受,也永遠不會有一模一樣的境遇。 很多時候,你以為看到了全貌,但其實只有冰山一角。永遠 ...
  • 最大公約數演算法不是很無聊,計算最大公約數是數學中一個重要的概念,可以用於判斷兩個數是否互質、求分數的約分等,在很多領域都有廣泛的應用。具體如下: 判斷兩個數是否互質:兩個數的最大公約數為1,說明這兩個數是互質的。 求分數的約分:將分子和分母的最大公約數約分掉,使得分數的值不變。 求同餘方程的最小正整 ...
一周排行
    -Advertisement-
    Play Games
  • 1、預覽地址:http://139.155.137.144:9012 2、qq群:801913255 一、前言 隨著網路的發展,企業對於信息系統數據的保密工作愈發重視,不同身份、角色對於數據的訪問許可權都應該大相徑庭。 列如 1、不同登錄人員對一個數據列表的可見度是不一樣的,如數據列、數據行、數據按鈕 ...
  • 前言 上一篇文章寫瞭如何使用RabbitMQ做個簡單的發送郵件項目,然後評論也是比較多,也是準備去學習一下如何確保RabbitMQ的消息可靠性,但是由於時間原因,先來說說設計模式中的簡單工廠模式吧! 在瞭解簡單工廠模式之前,我們要知道C#是一款面向對象的高級程式語言。它有3大特性,封裝、繼承、多態。 ...
  • Nodify學習 一:介紹與使用 - 可樂_加冰 - 博客園 (cnblogs.com) Nodify學習 二:添加節點 - 可樂_加冰 - 博客園 (cnblogs.com) 介紹 Nodify是一個WPF基於節點的編輯器控制項,其中包含一系列節點、連接和連接器組件,旨在簡化構建基於節點的工具的過程 ...
  • 創建一個webapi項目做測試使用。 創建新控制器,搭建一個基礎框架,包括獲取當天日期、wiki的請求地址等 創建一個Http請求幫助類以及方法,用於獲取指定URL的信息 使用http請求訪問指定url,先運行一下,看看返回的內容。內容如圖右邊所示,實際上是一個Json數據。我們主要解析 大事記 部 ...
  • 最近在不少自媒體上看到有關.NET與C#的資訊與評價,感覺大家對.NET與C#還是不太瞭解,尤其是對2016年6月發佈的跨平臺.NET Core 1.0,更是知之甚少。在考慮一番之後,還是決定寫點東西總結一下,也回顧一下.NET的發展歷史。 首先,你沒看錯,.NET是跨平臺的,可以在Windows、 ...
  • Nodify學習 一:介紹與使用 - 可樂_加冰 - 博客園 (cnblogs.com) Nodify學習 二:添加節點 - 可樂_加冰 - 博客園 (cnblogs.com) 添加節點(nodes) 通過上一篇我們已經創建好了編輯器實例現在我們為編輯器添加一個節點 添加model和viewmode ...
  • 前言 資料庫併發,數據審計和軟刪除一直是數據持久化方面的經典問題。早些時候,這些工作需要手寫複雜的SQL或者通過存儲過程和觸發器實現。手寫複雜SQL對軟體可維護性構成了相當大的挑戰,隨著SQL字數的變多,用到的嵌套和複雜語法增加,可讀性和可維護性的難度是幾何級暴漲。因此如何在實現功能的同時控制這些S ...
  • 類型檢查和轉換:當你需要檢查對象是否為特定類型,並且希望在同一時間內將其轉換為那個類型時,模式匹配提供了一種更簡潔的方式來完成這一任務,避免了使用傳統的as和is操作符後還需要進行額外的null檢查。 複雜條件邏輯:在處理複雜的條件邏輯時,特別是涉及到多個條件和類型的情況下,使用模式匹配可以使代碼更 ...
  • 在日常開發中,我們經常需要和文件打交道,特別是桌面開發,有時候就會需要載入大批量的文件,而且可能還會存在部分文件缺失的情況,那麼如何才能快速的判斷文件是否存在呢?如果處理不當的,且文件數量比較多的時候,可能會造成卡頓等情況,進而影響程式的使用體驗。今天就以一個簡單的小例子,簡述兩種不同的判斷文件是否... ...
  • 前言 資料庫併發,數據審計和軟刪除一直是數據持久化方面的經典問題。早些時候,這些工作需要手寫複雜的SQL或者通過存儲過程和觸發器實現。手寫複雜SQL對軟體可維護性構成了相當大的挑戰,隨著SQL字數的變多,用到的嵌套和複雜語法增加,可讀性和可維護性的難度是幾何級暴漲。因此如何在實現功能的同時控制這些S ...