香港云主机最佳企业级服务商!

ADSL拨号VPS包含了中国大陆(联通,移动,电信,)

中国香港,国外拨号VPS。

当前位置:云主机 > python >

电信ADSL拨号VPS
联通ADSL拨号VPS
移动ADSL拨号VPS

Python爬虫实现验证码登录代码实例


时间:2022-04-02 10:34 作者:admin610456


很多网站为了避免被恶意访问,需要设置验证码登录,避免非人类的访问,python/' target='_blank'>python爬虫实现验证码登录的原理则是先到登录页面将生成的验证码保存下来,然后人为输入后,包装后再POST给服务器,实现验证,这里还涉及到了Cookie,其实Cookie保存在本地主机上,避免用户重复输入用户名和密码,在连接服务器的时候将访问连接和Cookie组装起来POST给服务器。

这里涉及到了两次向服务器POST,一次是Cookie,这里还自行设计想要Cookie的内容,由于是要登录,Cookie中存放的则是用户名和密码。第二次POST则是向服务器提交验证。

这里用到Python3,主要用到的包是re urllib.request http.cookiejar

上代码,借鉴了别人的代码~~~

import reimport urllib.requestimport http.cookiejar#from http.comkie import CookieJar 上面那句和这句等同 loginurl='https://www.douban.com/accounts/login'cookie = http.cookiejar.CookieJar()opener = urllib.request.build_opener(urllib.request.HTTPCookieProcessor)#在已存的Cookie下建立连接 params={}params['form_email']='用户名'params['form_password']='密码'#这里写上已有的用户名和密码params['source']='http://www.douban.com/accounts/login' #从首页提交登陆response = opener.open(loginurl,urllib.parse.urlencode(params).encode('utf-8'))#urllib.parse.urlencode(params).encode('utf-8')这个是向服务#器POST的内容,可以打印一下response.geturl()请求的连接看一下#print(response.geturl()[0:33])#验证成功跳转至登陆页if response.geturl()[0:33]=='https://accounts.douban.com/login':    html = response.read().decode('utf-8')    #print(html),可以先打印一下文件内容,为了看到网页元素更方便的写正则,可以复制下来,在需要获取的地方用(.+?)表示,然后用group()元组来取得,    #验证图片地址    imgurl=re.search('<img id="captcha_image" src="(.+?)" alt="captcha" class="captcha_image"/>',html)    if imgurl:       url=imgurl.group(1)       #print(url)       #将验证码以v.jpg保存在本地,在输入验证码的时候可以手工输入       res=urllib.request.urlretrieve(url,'v.jpg')       captcha = re.search('<input type="hidden" name="captcha-id" value="(.+?)"/>',html)       #print(captcha.group(1))       if captcha:           vcode=input('请输入图片上的验证码:')           params["captcha-solution"] = vcode           params["captcha-id"] = captcha.group(1)#这个是动态生成的,需要从网页中获得           params["user_login"] = "登录"           #提交验证码验证           response = opener.open(loginurl,urllib.parse.urlencode(params).encode('utf-8'))           if response.geturl()=="https://www.douban.com/":              print("login sucess")

以上所述是小编给大家介绍的Python爬虫实现验证码登录详解整合,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

(责任编辑:admin)






帮助中心
会员注册
找回密码
新闻中心
快捷通道
域名登录面板
虚机登录面板
云主机登录面板
关于我们
关于我们
联系我们
联系方式

售前咨询:17830004266(重庆移动)

企业QQ:383546523

《中华人民共和国工业和信息化部》 编号:ICP备00012341号

Copyright © 2002 -2018 香港云主机 版权所有
声明:香港云主机品牌标志、品牌吉祥物均已注册商标,版权所有,窃用必究

云官方微信

在线客服

  • 企业QQ: 点击这里给我发消息
  • 技术支持:383546523

  • 公司总台电话:17830004266(重庆移动)
  • 售前咨询热线:17830004266(重庆移动)