滑动方法:有一种简单的滑块验证码,这种验证码要完成验证很简单,把左边的滑块按着向右拖动。
拖动到最右边,就可以完成验证了,这里有验证通过的提示的。
复杂的滑块,是一种类似拼图的形式的。拖动滑块到图中缺口位置就行。
当你没有正确完成,在滑块下方会有提示信息的。
当滑块显示的图片不是很清晰时,我们可以点击下方的刷新按钮,重新换一个拼图的。
当把滑块拖动到缺口位置时,就会验证通过。当图片中看不清晰时,可以刷新换一个图片的。
1、手机网页无法滑动验证,导致该现象的原因有很多,有可能是网络的问题,导致网页加载崩溃,验证过程中无法滑动。也有可能是浏览器模式不兼容,可以尝试从极速模式转变成兼容模式。
2、滑动拼图验证的正确姿势:点击验证按钮后弹出滑动拼图的验证浮窗;按住滑块不放,向右拖动,仔细将图片中的拼块进行拼合;当拼图拼合完毕后松手,验证便顺利通过。
目前滑动验证码的功能主要还是增加用户的安全,验证的是这是人为操作还是机器操作,防止一些不法分子利用自动程序恶意注册登录、暴力破解密码以及批量操作(刷单、发帖)等行为。如果没有验证码,暴力破解密码后就可以直接登录,相反,如果设置了验证码,程序很难识别,那么就无法登录成功。除此之外,还可以防止黑客恶意攻击从而导致服务器压力太大而崩溃,比如论坛灌水、刷页、刷票等,有些论坛回复需要输入验证码就是出于这个目的。
1、识别判断出现的滑动验证码。
这个步骤并不复杂,在编程里有很多这样的调试工具,根据实际应用场景选择合适的专业工具。然后利用一段获取图片的代码自动获取到带有滑动验证码的图片的信息。最后通过相应代码获取它们的网络地址,并将其下载并保存到本地。
2、确定滑动验证码的滑动位置,如果是那种带有缺口位置的验证码,就需要拖动拼合滑块才能完成验证。
将保存在本地的带有滑动验证码的图片调出来然后分析图片中的相关信息。这个步骤,就需要用到图像匹配技术。通俗的讲,就是用相应的原生代码进行图像匹配识别以及坐标定位。
3、根据上述收集到相关信息计算滑块移动轨迹并模拟人移动滑块的整个过程。
计算出了滑块移动的轨迹图,接下来就需要模拟人移动滑块的过程。现在的滑动验证码识别安全性很高,绝大多数都加入了机器学习模型,也就是说,人在移动滑块的时候不可能是匀速的。所以说,只是简单的匀速滑动肯定是被认定为机器操作。因此模拟人拖动滑块的过程中需要加入几个过程,比如先加速,再减速,适当加入回退和随机抖动,尽可能的模拟人的行为。滑动的过程可以通过在代码中设置相应变量,再加上相应公式就可以解决,对于专业人员并不复杂。
from selenium import webdriver
from selenium.webdriver.support.ui import WebDriverWait
from selenium.webdriver.common.action_chains import ActionChains
import PIL.Image as image
import time,re, random
import requests
try:
from StringIO import StringIO
except ImportError:
from io import StringIO
#爬虫模拟的浏览器头部信息
agent = 'Mozilla/5.0 (Windows NT 5.1; rv:33.0) Gecko/20100101 Firefox/33.0'
headers = {
'User-Agent': agent
}
# 根据位置对图片进行合并还原
# filename:图片
# location_list:图片位置
#内部两个图片处理函数的介绍
#crop函数带的参数为(起始点的横坐标,起始点的纵坐标,宽度,高度)
#paste函数的参数为(需要修改的图片,粘贴的起始点的横坐标,粘贴的起始点的纵坐标)
def get_merge_image(filename,location_list):
#打开图片文件
im = image.open(filename)
#创建新的图片,大小为260*116
new_im = image.new('RGB', (260,116))
im_list_upper=[]
im_list_down=[]
# 拷贝图片
for location in location_list:
#上面的图片
if location['y']==-58:
im_list_upper.append(im.crop((abs(location['x']),58,abs(location['x'])+10,166)))
#下面的图片
if location['y']==0:
im_list_down.append(im.crop((abs(location['x']),0,abs(location['x'])+10,58)))
new_im = image.new('RGB', (260,116))
x_offset = 0
#黏贴图片
for im in im_list_upper:
new_im.paste(im, (x_offset,0))
x_offset += im.size[0]
x_offset = 0
for im in im_list_down:
new_im.paste(im, (x_offset,58))
x_offset += im.size[0]
return new_im
#下载并还原图片
# driver:webdriver
# div:图片的div
def get_image(driver,div):
#找到图片所在的div
background_images=driver.find_elements_by_xpath(div)
location_list=[]
imageurl=''
#图片是被CSS按照位移的方式打乱的,我们需要找出这些位移,为后续还原做好准备
for background_image in background_images:
location={}
#在html里面解析出小图片的url地址,还有长高的数值
location['x']=int(re.findall("background-image: url\(\"(.*)\"\); background-position: (.*)px (.*)px;",background_image.get_attribute('style'))[0][1])
location['y']=int(re.findall("background-image: url\(\"(.*)\"\); background-position: (.*)px (.*)px;",background_image.get_attribute('style'))[0][2])
imageurl=re.findall("background-image: url\(\"(.*)\"\); background-position: (.*)px (.*)px;",background_image.get_attribute('style'))[0][0]
location_list.append(location)
#替换图片的后缀,获得图片的URL
imageurl=imageurl.replace("webp","jpg")
#获得图片的名字
imageName = imageurl.split('/')[-1]
#获得图片
session = requests.session()
r = session.get(imageurl, headers = headers, verify = False)
#下载图片
with open(imageName, 'wb') as f:
f.write(r.content)
f.close()
#重新合并还原图片
image=get_merge_image(imageName, location_list)
return image
#对比RGB值
def is_similar(image1,image2,x,y):
pass
#获取指定位置的RGB值
pixel1=image1.getpixel((x,y))
pixel2=image2.getpixel((x,y))
for i in range(0,3):
# 如果相差超过50则就认为找到了缺口的位置
if abs(pixel1[i]-pixel2[i])=50:
return False
return True
#计算缺口的位置
def get_diff_location(image1,image2):
i=0
# 两张原始图的大小都是相同的260*116
# 那就通过两个for循环依次对比每个像素点的RGB值
# 如果相差超过50则就认为找到了缺口的位置
for i in range(0,260):
for j in range(0,116):
if is_similar(image1,image2,i,j)==False:
return i
#根据缺口的位置模拟x轴移动的轨迹
def get_track(length):
pass
list=[]
#间隔通过随机范围函数来获得,每次移动一步或者两步
x=random.randint(1,3)
#生成轨迹并保存到list内
while length-x=5:
list.append(x)
length=length-x
x=random.randint(1,3)
#最后五步都是一步步移动
for i in range(length):
list.append(1)
return list
#滑动验证码破解程序
def main():
#打开火狐浏览器
driver = webdriver.Firefox()
#用火狐浏览器打开网页
driver.get("htest.com/exp_embed")
#等待页面的上元素刷新出来
WebDriverWait(driver, 30).until(lambda the_driver: the_driver.find_element_by_xpath("//div[@class='bb97-0d69-f42f-8564 gt_slider_knob gt_show']").is_displayed())
WebDriverWait(driver, 30).until(lambda the_driver: the_driver.find_element_by_xpath("//div[@class='0d69-f42f-8564-5124 gt_cut_bg gt_show']").is_displayed())
WebDriverWait(driver, 30).until(lambda the_driver: the_driver.find_element_by_xpath("//div[@class='f42f-8564-5124-100f gt_cut_fullbg gt_show']").is_displayed())
#下载图片
image1=get_image(driver, "//div[@class='8564-5124-100f-174e gt_cut_bg gt_show']/div")
image2=get_image(driver, "//div[@class='5124-100f-174e-1b4c gt_cut_fullbg gt_show']/div")
#计算缺口位置
loc=get_diff_location(image1, image2)
#生成x的移动轨迹点
track_list=get_track(loc)
#找到滑动的圆球
element=driver.find_element_by_xpath("//div[@class='100f-174e-1b4c-a5d9 gt_slider_knob gt_show']")
location=element.location
#获得滑动圆球的高度
y=location['y']
#鼠标点击元素并按住不放
print ("第一步,点击元素")
ActionChains(driver).click_and_hold(on_element=element).perform()
time.sleep(0.15)
print ("第二步,拖动元素")
track_string = ""
for track in track_list:
#不能移动太快,否则会被认为是程序执行
track_string = track_string + "{%d,%d}," % (track, y - 445)
#xoffset=track+22:这里的移动位置的值是相对于滑动圆球左上角的相对值,而轨迹变量里的是圆球的中心点,所以要加上圆球长度的一半。
#yoffset=y-445:这里也是一样的。不过要注意的是不同的浏览器渲染出来的结果是不一样的,要保证最终的计算后的值是22,也就是圆球高度的一半
ActionChains(driver).move_to_element_with_offset(to_element=element, xoffset=track+22, yoffset=y-445).perform()
#间隔时间也通过随机函数来获得,间隔不能太快,否则会被认为是程序执行
time.sleep(random.randint(10,50)/100)
print (track_string)
#xoffset=21,本质就是向后退一格。这里退了5格是因为圆球的位置和滑动条的左边缘有5格的距离
ActionChains(driver).move_to_element_with_offset(to_element=element, xoffset=21, yoffset=y-445).perform()
time.sleep(0.1)
ActionChains(driver).move_to_element_with_offset(to_element=element, xoffset=21, yoffset=y-445).perform()
time.sleep(0.1)
ActionChains(driver).move_to_element_with_offset(to_element=element, xoffset=21, yoffset=y-445).perform()
time.sleep(0.1)
ActionChains(driver).move_to_element_with_offset(to_element=element, xoffset=21, yoffset=y-445).perform()
time.sleep(0.1)
ActionChains(driver).move_to_element_with_offset(to_element=element, xoffset=21, yoffset=y-445).perform()
print ("第三步,释放鼠标")
#释放鼠标
ActionChains(driver).release(on_element=element).perform()
time.sleep(3)
#点击验证
# submit = driver.find_element_by_xpath("//div[@class='174e-1b4c-a5d9-a5c7 gt_ajax_tip success']")
# print(submit.location)
# time.sleep(5)
#关闭浏览器,为了演示方便,暂时注释掉.
#driver.quit()
#主函数入口
if __name__ == '__main__':
pass
main()
拖动滑块完成验证,是现在很多网站或app登录账号或注册账号时的一种验证手段。怎么拖动滑块完成验证?很简单的,下面我们来看一下。
工具/原料
简单的滑块
1/2 分步阅读
有一种简单的滑块验证码,这种验证码要完成验证很简单,把左边的滑块按着向右拖动。
2/2
拖动到最右边,就可以完成验证了,这里有验证通过的提示的。
「方圆仪器」材料检测仪器「方圆仪器」疲劳试验机
广告
复杂的滑块
1/4
复杂的滑块,是一种类似拼图的形式的。拖动滑块到图中缺口位置就行。
疲劳试验机-长春试验机厂-71年生产经验
广告
2/4
当你没有正确完成,在滑块下方会有提示信息的。
温州凯瑞标识实力厂商,免费打样,免费设计,厂家直销
广告
3/4
当滑块显示的图片不是很清晰时,我们可以点击下方的刷新按钮,重新换一个拼图的。
4/4
当把滑块拖动到缺口位置时,就会验证通过。
总结:
1/1
要完成滑块的验证,很简单:
1. 拖动左边的滑块向右移动。
2. 移到最右边,就可以完成验证。
3. 对于复杂的,拼图形式的,则是把滑块拖动到图中缺口的位置。
注意事项
当图片中看不清晰时,可以刷新换一个图片的。
手机上的滑块验证也是相同的。
有多种形式的验证码: ① 字母和数字:按字样打入即可。 ② 拖动形:将小图片拖动到有缺口的图片中。 ③ 点击勾选。 ④ 外文或繁体字:一般要采用外文或特殊输入法。但多元输入法(多元汉字与图形符号输入法)均可直接输入。
macbookm1的auto cad,求求了 点击下载:mac cad版安装包百度盘下载很多新朋友接触CAD,或者是工作需要CAD软件的朋友,一定在网上要百度这些问题,CAD下载,CAD软件,CAD软...
中国顶级黑客,为报南海王伟撞机之仇,将国旗插到了白宫上,他是谁... 1、今天我要说的是中国顶级黑客林勇的故事,为报南海王伟撞机之仇,将国旗插到了白宫上。2、有一位叫林勇的黑客,技术非常顶尖,早在他一...
小说黑客女主角有几个 你好,小说黑客女主角共有5个,分别为凌羽默,穆霜,李知月和欧阳香,该书男主名为石磊。是一本现代都市小说。女主是黑客的小说 重生之黑而不死而为神力荐,女主黑客技术很强,男主黑客技术...
苹果破解软件哪里有下载 直接在淘宝上搜吧,那些很厉害的专业软解也就是几块到几十块钱,提供下载和注册码,就跟正式版一样了,可以在线更新、升级;比那些简单的破解版要好。苹果破解版地铁跑酷怎么下载 你好很高...
可以多开账号的软件有哪些微信分身软件推荐 1、多聊(微信pc版多开软件)软件类型:电脑软件 软件介绍:【基本介绍】多聊是一款功能强大的微信pc版多开软件,拥有账号快速切换,微信多开,消息提示等多种功能...
求 校园动漫 帅哥多点 如 樱兰 SA 吸血鬼骑士 其实我对伪后宫。。知道的很少。。我知道后宫多。。你看下面这几个可以吗?爱丽丝学园 传说中可以算为正后宫也可以算为逆后宫的动漫完美小姐进化论 我不太...