使用Python爬虫怎么实现验证码登录?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。
创新互联公司是专业的华池网站建设公司,华池接单;提供成都网站建设、网站建设,网页设计,网站设计,建网站,PHP网站建设等专业做网站服务;采用PHP框架,可快速的进行华池网站开发网页制作和功能扩展;专业做搜索引擎喜爱的网站,专业的做网站团队,希望更多企业前来合作!import re import urllib.request import 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('',html) if imgurl: url=imgurl.group(1) #print(url) #将验证码以v.jpg保存在本地,在输入验证码的时候可以手工输入 res=urllib.request.urlretrieve(url,'v.jpg') captcha = re.search('',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")
看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注创新互联行业资讯频道,感谢您对创新互联的支持。