滑块验证码也是常见反爬手段,而且网上介绍文章也不少,但是多数都是能够获取到原图和有缺口的图,然后做点对点的对比获得缺口位置,这里主要是怎么处理没有原图。
1、例子
B站,QQ系。
B站会对照片进行打乱,但是可以反向组合形成两张照片,或者直接selenium截图也行。但是QQ系,是没有原图的。
1、B站
2、QQ
2、解决思路
1、虽然他们没有原图,但是它的缺口位置有白边,所以每一个点对他右侧和下侧各26个像素求和,然后这些像素往右下移动一个像素再求和,达到阈值就判断是图像的左上角点;阈值分别是35000/15000。
这次的检测的位置就是下图左上角那一个点。
2、判断出点位置就简单了,剩下的就是缩放比例,使用selenium控制移动滑块到达缺口位置。再此增加一个功能,就是将对应的照片和计算出来的距离保存到本地文件,每次都先使用照片的文件名查找是否计算过,没计算的才会调用这个匹配查找算法。
3、制移动滑块到达缺口位置这个部分,一般都先加速后减速,见过测试,代码参数百分百成功。
3、工具
主要使用selenium、pillow包
4、代码
# 匹配算法
def getImgDistance(name):
img=Image.open(f"./easygo/image/{name}.jpg"