AVt天堂网 手机版,亚洲va久久久噜噜噜久久4399,天天综合亚洲色在线精品,亚洲一级Av无码毛片久久精品

當前位置:首頁 > 科技  > 軟件

不掉頭發(fā)“逆向”旋轉(zhuǎn)驗證碼

來源: 責編: 時間:2024-07-17 07:43:50 580觀看
導讀驗證碼是爬蟲程序繞不過的坎,有各種各樣的驗證碼擋在前進的道路上,比如本文將要重點介紹的旋轉(zhuǎn)驗證碼,網(wǎng)上能找到不少關于這種驗證碼的逆向方法,整體思路都是一樣的,首先需要通過深度學習模型識別出圖片的旋轉(zhuǎn)角度,接下來逆

驗證碼是爬蟲程序繞不過的坎,有各種各樣的驗證碼擋在前進的道路上,比如本文將要重點介紹的旋轉(zhuǎn)驗證碼,網(wǎng)上能找到不少關于這種驗證碼的逆向方法,整體思路都是一樣的,首先需要通過深度學習模型識別出圖片的旋轉(zhuǎn)角度,接下來逆向分析加密旋轉(zhuǎn)角度的一系列過程的js代碼,根據(jù)逆向出的過程構(gòu)造出對應的參數(shù),模擬驗證碼驗證接口調(diào)用實現(xiàn)旋轉(zhuǎn)驗證碼的識別。7Hm28資訊網(wǎng)——每日最新資訊28at.com

不得不說,獨自搞定這一切相當耗時、耗力,而且還可能無功而返,怪不得逆向會經(jīng)常伴隨著掉頭發(fā)的調(diào)侃,即使參照網(wǎng)上大佬們的技術文章,真正實踐起來才發(fā)現(xiàn)每走一步都可能有坑,有可能是平臺反爬策略更新導致和原文已不一致,也可能因為內(nèi)容比較敏感導致關鍵細節(jié)被故意隱藏,還可能是技術實力欠缺等等。總之,這種逆向的方法讓很多人倍感無力,也許硬著頭皮研究下去最終可以搞定,但肯定需要花費不少的時間,而時間往往是不夠用的。7Hm28資訊網(wǎng)——每日最新資訊28at.com

這里提出另外一種經(jīng)過驗證可行的解決方案,那就是直接模擬用戶鼠標操作去拖動滑塊實現(xiàn)旋轉(zhuǎn)驗證碼識別(其他驗證碼也可以使用這個思路)。簡單分析下下面的旋轉(zhuǎn)碼操作就可以發(fā)現(xiàn)滑塊滑到頭,圖片就旋轉(zhuǎn)了一圈360°,它們之間是線性關系,可以計算出這個比例關系,一旦確定了圖片的旋轉(zhuǎn)角度就可以根據(jù)這個比例關系換算出滑塊滑動的距離,然后模擬拖動滑塊就完成了旋轉(zhuǎn)驗證碼的驗證。7Hm28資訊網(wǎng)——每日最新資訊28at.com

7Hm28資訊網(wǎng)——每日最新資訊28at.com

這種處理驗證碼的方式完全不需要去逆向分析前端代碼,完全是站在用戶的視角在操作,當然它顯得不夠極客,可能性能也稍差點,但是真的不會掉太多頭發(fā),關鍵是它可以解決問題,不管黑貓白貓,能抓老鼠就是好貓。按照這個思路的話,只需要重點解決下面幾個問題:7Hm28資訊網(wǎng)——每日最新資訊28at.com

截取圖片數(shù)據(jù)

這一步的目的是提取旋轉(zhuǎn)驗證碼圖片數(shù)據(jù),用于接下來使用深度學習模型識別旋轉(zhuǎn)角度。可以通過JavaScript代碼創(chuàng)建canvas畫布并繪制驗證碼圖像的方式來獲取圖片數(shù)據(jù),如果你使用selenium、playwright這樣的自動化框架的話,它們都支持直接執(zhí)行js代碼并獲取返回結(jié)果。這里需要注意的地方,一是圖像元素需要設置允許跨域,否則無法獲取到圖片數(shù)據(jù),而且設置跨域?qū)傩詴|發(fā)重新請求圖片,如果設置跨域后立刻繪制圖像是獲取不到數(shù)據(jù)的,需要等待響應圖片渲染完成。另外一個就是canvas.toDataURL需要指定圖片格式為png,因為jpeg是不支持透明背景的,使用jpeg格式會導致旋轉(zhuǎn)角度識別庫識別旋轉(zhuǎn)角度完全錯誤。7Hm28資訊網(wǎng)——每日最新資訊28at.com

// img_selector表示驗證碼圖片選擇器var imgelm=document.querySelector(img_selector);// 設置允許跨域,否則無法獲取圖片數(shù)據(jù)// TIP:設置跨域后會觸發(fā)重新請求圖片,// 立刻獲取圖片尺寸結(jié)果為全0,需要等待一段時間重新獲取imgelm.setAttribute("crossOrigin","anonymous");var canvas = document.createElement('canvas');var ctx = canvas.getContext('2d');canvas.width=imgelm.naturalWidth;canvas.height=imgelm.naturalHeight;ctx.drawImage(imgelm, 0, 0);// 注意:jpeg格式不支持透明背景,這里使用png格式var dataURL = canvas.toDataURL('image/png');return dataURL;

識別旋轉(zhuǎn)角度

關于旋轉(zhuǎn)角度識別,可以使用https://github.com/Starry-OvO/rotate-captcha-crack這個模型,這里通過運行server.py開啟一個web服務,通過調(diào)用接口,傳入圖片數(shù)據(jù)會返回識別出的旋轉(zhuǎn)角度。7Hm28資訊網(wǎng)——每日最新資訊28at.com

(使用指導參考:https://cloud.tencent.com/developer/article/2418786)7Hm28資訊網(wǎng)——每日最新資訊28at.com

不過,由于百度旋轉(zhuǎn)驗證碼圖片已經(jīng)升級,圖片全部使用AI生成,更不易識別,當前的模型識別成功率有點低,不過可以通過增加重試來規(guī)避這個問題,如果你對深度學習比較熟悉的話也可以使用它的模型重新訓練最新的驗證碼圖片。7Hm28資訊網(wǎng)——每日最新資訊28at.com

另外,百度除了會出現(xiàn)旋轉(zhuǎn)驗證碼之外,有時候也會出現(xiàn)其他類型驗證,比如滑塊驗證碼,這種情況就需要同時處理滑塊驗證碼和旋轉(zhuǎn)驗證碼,思路也是一樣的,至于滑塊驗證碼的識別可以使用ddddocr這個庫(https://gitee.com/fkgeek/ddddocr),官網(wǎng)文檔給出了詳細的使用方法。7Hm28資訊網(wǎng)——每日最新資訊28at.com

模擬拖動滑塊

不管是滑塊驗證碼還是旋轉(zhuǎn)驗證碼,識別出了圖片滑塊的距離、旋轉(zhuǎn)角度之后都可以簡單地通過線性關系得出拖動滑塊的距離,接下來就是模擬滑塊拖動指定距離就可以了,下面的js代碼實現(xiàn)了模擬拖動滑塊的功能。代碼中滑動距離僅給出示例,實際運行時請改為換算后的動態(tài)值。7Hm28資訊網(wǎng)——每日最新資訊28at.com

() => {    // selector:滑塊選擇器   offsetX: 滑動距離	function slide(selector, offsetX) {	    // 滑塊定位		let slider = document.querySelector(selector);		// 計算滑塊矩形區(qū)域?qū)亲鴺?	let rect = slider.getBoundingClientRect(),			x0 = rect.x || rect.left,			y0 = rect.y || rect.top,			x1 = x0 + offsetX, 			y1 = y0;		// 模擬鼠標按下動作		let mousedown = document.createEvent('MouseEvents');		mousedown.initMouseEvent('mousedown', true, true, window, 0, x0, y0, x0, y0, false, false, false, false, 0, null);		slider.dispatchEvent(mousedown);  				//模擬鼠標拖動動作,將滑塊移動距離簡單拆分為4個相同距離的動作		let mousemove = document.createEvent('MouseEvents');		mousemove.initMouseEvent('mousemove', true, true, window, 0, x0+offsetX/4, y1, x0+offsetX/4, y1, false, false, false, false, 0, null);		slider.dispatchEvent(mousemove);		mousemove.initMouseEvent('mousemove', true, true, window, 0, x0+offsetX/2, y1, x0+offsetX/2, y1, false, false, false, false, 0, null);		slider.dispatchEvent(mousemove);		mousemove.initMouseEvent('mousemove', true, true, window, 0, x0+3*offsetX/4, y1, x0+3*offsetX/4, y1, false, false, false, false, 0, null);		slider.dispatchEvent(mousemove);		mousemove.initMouseEvent('mousemove', true, true, window, 0, x0+offsetX, y1, x0+offsetX, y1, false, false, false, false, 0, null);		slider.dispatchEvent(mousemove);			    // 模擬鼠標釋放動作		let mouseout = document.createEvent('MouseEvents');		mouseout.initMouseEvent('mouseup', true, true, window, 0, x1, y1, x1, y1, false, false, false, false, 0, null);		slider.dispatchEvent(mouseout);	}	// 執(zhí)行滑塊拖動,以下distance和滑塊選擇器只是示例,根據(jù)實際情況進行調(diào)整	var distance = 200;	slide('div.passMod_slide-btn', distance);}

最后,展示一下通過上面的思路使用playwright實現(xiàn)的旋轉(zhuǎn)驗證碼的識別過程,本次出現(xiàn)了兩次驗證碼,第一次是滑塊驗證碼,通過后又出現(xiàn)了旋轉(zhuǎn)驗證碼,可以發(fā)現(xiàn)旋轉(zhuǎn)驗證碼識別了3次才成功,就是因為模型對于最新的百度旋轉(zhuǎn)驗證碼圖片角度識別率變差導致的,實現(xiàn)上通過增加重試次數(shù)進行規(guī)避。經(jīng)測試,無界面模式也可以正常運行。7Hm28資訊網(wǎng)——每日最新資訊28at.com

7Hm28資訊網(wǎng)——每日最新資訊28at.com

參考文獻:
[1]https://cloud.tencent.com/developer/article/2418786
[2]https://github.com/Starry-OvO/rotate-captcha-crack
[3]https://gitee.com/fkgeek/ddddocr
[4]https://blog.csdn.net/m0_58618019/article/details/1329184047Hm28資訊網(wǎng)——每日最新資訊28at.com

本文鏈接:http://www.tebozhan.com/showinfo-26-101270-0.html不掉頭發(fā)“逆向”旋轉(zhuǎn)驗證碼

聲明:本網(wǎng)頁內(nèi)容旨在傳播知識,若有侵權等問題請及時與本網(wǎng)聯(lián)系,我們將在第一時間刪除處理。郵件:2376512515@qq.com

上一篇: 說說MQ延遲隊列實現(xiàn)原理?

下一篇: 我們一起聊聊 Nginx 后端長連接

標簽:
  • 熱門焦點
  • K60至尊版狂暴引擎2.0加持:超177萬跑分斬獲性能第一

    Redmi的后性能時代戰(zhàn)略發(fā)布會今天下午如期舉辦,在本次發(fā)布會上,Redmi公布了多項關于和聯(lián)發(fā)科的深度合作,以及新機K60 Ultra在軟件和硬件方面的特性,例如:“K60 至尊版,雙芯旗艦
  • 中興AX5400Pro+上手體驗:再升級 雙2.5G網(wǎng)口+USB 3.0這次全都有

    2021年11月的時候,中興先后發(fā)布了兩款路由器產(chǎn)品,中興AX5400和中興AX5400 Pro,從產(chǎn)品命名上就不難看出這是隸屬于同一系列的,但在外觀設計上這兩款產(chǎn)品可以說是完全沒一點關系
  • 摸魚心法第一章——和配置文件說拜拜

    為了能摸魚我們團隊做了容器化,但是帶來的問題是服務配置文件很麻煩,然后大家在群里進行了“親切友好”的溝通圖片圖片圖片圖片對比就對比,簡單對比下獨立配置中心和k8s作為配
  • 如何使用JavaScript創(chuàng)建一只圖像放大鏡?

    譯者 | 布加迪審校 | 重樓如果您曾經(jīng)瀏覽過購物網(wǎng)站,可能遇到過圖像放大功能。它可以讓您放大圖像的特定區(qū)域,以便瀏覽。結(jié)合這個小小的重要功能可以大大改善您網(wǎng)站的用戶體驗
  • 在線圖片編輯器,支持PSD解析、AI摳圖等

    自從我上次分享一個人開發(fā)仿造稿定設計的圖片編輯器到現(xiàn)在,不知不覺已過去一年時間了,期間我經(jīng)歷了裁員失業(yè)、面試找工作碰壁,寒冬下一直沒有很好地履行計劃.....這些就放在日
  • 2023年,我眼中的字節(jié)跳動

    此時此刻(2023年7月),字節(jié)跳動從未上市,也從未公布過任何官方的上市計劃;但是這并不妨礙它成為中國最受關注的互聯(lián)網(wǎng)公司之一。從2016-17年的抖音強勢崛起,到2018年的“頭騰
  • 本地生活這塊肥肉,拼多多也想吃一口

    出品/壹覽商業(yè) 作者/李彥編輯/木魚拼多多也看上本地生活這塊蛋糕了。近期,拼多多在App首頁“充值中心”入口上線了本機生活界面。壹覽商業(yè)發(fā)現(xiàn),該界面目前主要
  • 新電商三兄弟,“抖快紅”成團!

    來源:價值研究所作 者:Hernanderz 隨著內(nèi)容電商的概念興起,抖音、快手、小紅書組成的“新電商三兄弟”成為業(yè)內(nèi)一股不可忽視的勢力,給阿里、京東、拼多多帶去了巨大壓
  • 最薄的14英寸游戲筆記本電腦 Alienware X14已可以購買

    2022年1月份在國際消費電子展(CES2022)上首次亮相的Alienware新品——Alienware X14現(xiàn)在已經(jīng)可以購買了,這款筆記本電腦被譽為世界上最薄的 14 英寸游戲筆
Top