python實(shí)現(xiàn)騰訊滑塊驗證碼識別
騰訊滑塊驗證碼識別,識別凹槽的x軸位置,mock滑塊的加速度。該項目公開API,提供識別和加速度模擬部分,第二部分模擬滑動進(jìn)行識別返回數(shù)據(jù)請求
項目地址:https://github.com/zhaojunlike/python-tecent-slider-crack
安裝python環(huán)境參考:https://janikarhunen.fi/how-to-install-python-3-6-1-on-centos-7
sudo yum install https://centos7.iuscommunity.org/ius-release.rpmsudo yum install python36upython3.6 -Vsudo yum install python36u-pipsudo yum install python36u-devel創(chuàng)建環(huán)境 Creating a virtualenv
python3.6 -m venv venv. venv/bin/activatepip install [package_name]# 安裝依賴pip install -r requirements.txt daemonize 運(yùn)行
# 參考 https://www.digitalocean.com/community/tutorials/how-to-serve-flask-applications-with-uswgi-and-nginx-on-ubuntu-18-04# Install the latest stable release:pip install uwsgi# ... or if you want to install the latest LTS (long term support) release,pip install https://projects.unbit.it/downloads/uwsgi-lts.tar.gz# 創(chuàng)建ln cp captcha.service /etc/systemd/system/captcha.servicesystemctl enable captcha.servicesystemctl start captcha.service
uwsgi --ini /usr/local/nginx/html/myblog/uwsgiconfig.ini#后臺運(yùn)行uwsgi --ini /usr/local/nginx/html/myblog/uwsgiconfig.ini --daemonize /usr/local/nginx/html/myblog/myblog.outnginx做代理
location /tx/ { add_header Access-Control-Allow-Origin *; includeuwsgi_params; uwsgi_pass 127.0.0.1:8008;}訪問api
請求圖片識別和加速度模擬
http://127.0.0.1:5000/tx/imagePOST /tx/image HTTP/1.1Host:hostContent-Type: application/jsonAccept: */*Cache-Control: no-cacheAccept-Encoding: gzip, deflateContent-Length: 1055Connection: keep-alivecache-control: no-cache{ 'url': '圖片的地址'}返回數(shù)據(jù){ 'data': {'list': [],//模擬的點(diǎn)'url': '',//圖片地址'x': 515,// x軸的偏移量 }, 'message': '解析成功'}模擬瀏覽器移動
const slider = {width: 680, point: 0, move: 0, steps: 0, posX: 0};//原本的高度 //開始計算移動的距離 slider.point = bgSize.width / slider.width * x; slider.move = handle.x + slider.point - 5; slider.steps = Math.random() * 100 / 30 + 100; slider.posX = handle.x + handle.width / 2; logger.info(`開始識別和移動滑塊`, slider); //滑塊的位置 await page.mouse.move(slider.posX, handle.y + handle.height / 3, {steps: slider.steps}); await page.mouse.down(); let val = handle.x; for (let i = 0; i < traces.length; i++) {val += bgSize.width / slider.width * (traces[i]);//縮放距離slider.move = val;if (val <= slider.posX) continue;await page.mouse.move(slider.move, handle.y + handle.height / 2 + 5); } await page.waitFor(100); await page.mouse.up();
驗證碼識別成功后悔返回驗證識別結(jié)果的Ticket

授權(quán)協(xié)議:只允許研究、學(xué)習(xí)目的的分享、使用、修改,不允許任何商業(yè)用途。
原文地址:https://segmentfault.com/a/1190000020618430
以上就是python實(shí)現(xiàn)騰訊滑塊驗證碼識別的詳細(xì)內(nèi)容,更多關(guān)于python 滑塊驗證碼識別的資料請關(guān)注好吧啦網(wǎng)其它相關(guān)文章!
相關(guān)文章:
1. 編程語言PHP在Web開發(fā)領(lǐng)域的優(yōu)勢在哪?2. 什么是python的自省3. 基于android studio的layout的xml文件的創(chuàng)建方式4. 詳解Android studio 動態(tài)fragment的用法5. Android如何加載Base64編碼格式圖片6. 圖文詳解vue中proto文件的函數(shù)調(diào)用7. 在IDEA中實(shí)現(xiàn)同時運(yùn)行2個相同的java程序8. .Net Core使用Coravel實(shí)現(xiàn)任務(wù)調(diào)度的完整步驟9. Vuex localStorage的具體使用10. 解決Android studio xml界面無法預(yù)覽問題

網(wǎng)公網(wǎng)安備