当前位置:淡墨SEO首页 > SEO软件 > js逆向百度旋转验证码并通过验证

js逆向百度旋转验证码并通过验证

淡墨SEO3年前 (2022-09-06)SEO软件19990

在公众号之前的一篇文章写到用pyppeteer模拟轨迹进行识别。https://mp.weixin.qq.com/s/aHeYmRMx4NIfN5shch-WfA 大家可以自行前往学习了解。本次带来一个更加轻松的识别通过,就是通过js完成距离通过验证。下面就主要讲解一下思路,具体操作验证还需要完善一下代码。

image.png

旋转验证码逆向的主要问题是解决动态参数,只要解决动态的参数的来源就可以。经过测试发现fs是变化的


image.png

进入断点测试,给相应位置打上断点。可以看到fs是通过AES加密

image.png


image.png


除了fk字段需要通过补js环境进行还原,其次就是as、backstr字段需要获取,这个可以requests模拟请求进行解析获取即可

image.pngimage.png

然后就是angle角度的识别,角度的识别,推荐文章:预测旋转角度推荐nanda大佬的文章:https://mp.weixin.qq.com/s/G5Bm0DfoUDy_a2KOc_gNRw 


在r.rzData中ac_c=round((o / 212),2),而o是滑动的距离,o=angle*212/360 (angle)是识别的角度。然后backstr是前面返回的,其他的所有参数都可固定,包括轨迹。那么ac_c =  (angle*212/360/212).toFixed(2).


接下来在代码中进行复现还原一下。


首先是获取旋转图片和backstr,图片地址和backstr都会在这个请求中响应,拿到响应数据就可以进行解析了。


image.png


 def getImg(self):
       
        self.session.get(self.url,headers=self.headers)
        params = {
            'callback': 'jQuery110204891335603986202_' + str(time.time()*1000),
            'ak':'c27bbc89afca0463650ac9bde68ebe06',
            'tk':'5186ttnIrhB1fBEkLt2uExpiLynx575uW1bx1HchF8dIw5m1j2PMQ5M4LGvMDVkzsNJED+1NmBKZjNwb+DoGQMwpSEETXal5AvVi9LjiHsOc9nnbIpz1iydwbSFWtFQKl2ggAufwNwxaINHUAZKgbwb5zQ==',
            'scene':'',
            'isios': 0,
            'type': 'spin',
            '_': str(time.time()*1000)
        }
        styleUrl = 'https://wappass.baidu.com/viewlog/getstyle'
        resp = self.session.get(url=styleUrl,headers=self.headers,params=params).text
        jsonStr = re.findall(r'.*?\((.*?)\)',resp,re.S)[0]
        jsonDict = json.loads(jsonStr)
        print(jsonDict)
        self.backstr = jsonDict['data']['backstr']
        print(self.backstr)
        imgUrl = unquote(jsonDict['data']['ext']['img'])
        imgContent = self.session.get(url=imgUrl,headers=self.headers).content
        image = Image.open(BytesIO(imgContent))
        image.save('1.png')

这样运行后,图片就保存到本地了,我们在本地查看一下待旋转的图片


image.png



其次就是获取as字段信息,as字段在一开始的请求响应中会出现,同样解析一下就可以获取

def getAs(self):
        self.session.get(self.url,headers=self.headers)
        params = {
            'callback': 'jQuery110204591104788231357_' + str(time.time()*1000),
            'ak':'c27bbc89afca0463650ac9bde68ebe06',
            '_': str(time.time()*1000)
        }
        resp = self.session.get(url=self.verifyUrl,headers=self.headers,params=params).text
        jsonStr = re.findall(r'.*?\((.*?)\)',resp,re.S)[0]
        jsonDict = json.loads(jsonStr)
        self.aas = jsonDict['data']['as']
        print(self.aas)


接下来重要的就是补crypto.js环境,然后获取fk字段参数信息。这里的r就是最终的fk字段信息了。

image.png

在python代码中调用fk信息。

def getFk(self):
        with open('code.js','r') as f:
            codejs = f.read()
        aesObj = execjs.compile(codejs).eval(f"get_fk({self.aas},{self.angle},{self.backstr})")


一切准备就绪,剩下的就是运行了,只要运行的op=1,那么验证码就识别通过了。

image.png


核心问题已经解决,由于时间关系,具体运行代码还需要完善,完善过后就可以正常调用接口进行识别距离,并通过验证。如果有朋友百度旋转验证码感兴趣,可以私信我获取源码,并教会大家使用。但是需要一定的有偿获取。

扫描二维码推送手机访问

文章内容均为原创,禁止转载!

本文链接:http://www.danmoseo.com/news/14.html

标签: js逆向

相关文章

某讯视频用python解析数据并下载视频mp4格式

某讯视频用python解析数据并下载视频mp4格式

国庆祝福祖国生日快乐。偶尔间,想做做视频剪辑,需要下载视频素材,但是在平台上的视频似乎不支持手动下载。自然学了python,可以试着用代码去下载视频,在这块找到相应的教学内容,本次内容主要是分享用python如何去获取下载某讯视频。下面为大家讲解一下。就拿最近比较火的昆仑神宫来做下视频解析下载,首先...

多进程线程查询关键词排名,速度达到1秒10个!

多进程线程查询关键词排名,速度达到1秒10个!

python多线程有两种,一种是多进程,另一种是多线程,对于线程基础知识层面,线程运行在进程中,一个进程可以有多个线程,而多线程只能在一个进程中运行。所以在多线程并发运行的同时,开启多进程进行并行操作。这样就可以最大化的利用计算机cpu的内核。需要源码的可以在我的商城获取>>>百度...

摆渡模拟点击关键词排名优化介绍

摆渡模拟点击关键词排名优化介绍

模拟点击的原理在于模拟用户打开浏览器,搜索关键词,后面进行一系列的模拟行为操作。在python代码中,用到的浏览器框架是selenium库,然后进行模拟点击整个过程的代码执行。源码商城》》》摆渡快排软件含源码教程视频演示:本次代码已经进行封包了,在运行的时候,只需要一键运行即可在安装方面导入数据库就...

百度旋转验证码ds字段api接口自动生成

百度旋转验证码ds字段api接口自动生成

最近有些做seo同行在问我,旋转验证码的源码怎么用啊,比如出现验证码的时候,怎么对接啊?还有的会问怎么对接易语言、C#,那真的尴尬了,其他语言不太会。其实旋转验证码的原理最终要的数据就是ds和tk字段信息,只要拿到这两个字段的信息,就可以对接了。所以这次做了百度旋转验证码ds字段api接口自动生成,...

百度贴吧包含指定关键词回复内容提取软件

百度贴吧包含指定关键词回复内容提取软件

这几天,有个用户找我做百度贴吧回复采集,将出现的验证码也识别通过,那么我正好有这个旋转验证码逆向源码,可以接入到百度贴吧中,只要出现验证码逆向通过就行了。爬虫采集的问题不大,主要是旋转验证码需要接入,接入的规则也是要根据网页的参数需求。视频演示:贴吧采集就不细说了,这里我用了多线程采集,速度已经非常...