import requests
from selenium import webdriver
from selenium.webdriver.common.by import By
from VerificationcodeProcessing import YdmVerify
import json
def getHTMLText(url):
try:
headers={'user-agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/104.0.5112.102 Safari/537.36 Edg/104.0.1293.63'}
res=requests.get(url,headers=headers)
print(res)
res.raise_for_status()
return res.content
except:
return ""
d = webdriver.Edge()
d.get('https://so.gushiwen.cn/user/login.aspx?')
username = d.find_element(By.ID,"email").send_keys("15128325796")
password = d.find_element(By.ID,"pwd").send_keys("123456789")
YdmVerify1 = d.find_element(By.ID,"imgCode")
url =YdmVerify1.get_attribute("src")
print(url)
text = getHTMLText(url)
with open("验证码识别.jpg","wb") as f:
f.write(text)
Y = YdmVerify()
with open('验证码识别.jpg', 'rb') as f:
s = f.read()
da = Y.common_verify(s, verify_type="10110")['data']['data']
#print(type(da),da)
YdmVerify1 = d.find_element(By.ID,"code").send_keys(da)
denglu = d.find_element(By.ID,"denglu").click()
想问问为啥和网站上的验证码不一致,显示验证码错误
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
3条回答 默认 最新
- CSDN专家-showbo 2022-10-19 10:00关注
webdriver和getHTMLText中的requests
不是同一个会话
,通过requests获取验证码识别后得到的内容在webdriver中输入肯定是错的。要获取webdriver中的验证码base64数据或者bytes数据,然后OCR解析进行其他处理,具体参考下面的
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥50 关于#html5#的问题:H5页面用户手机返回的时候跳转到指定页面例如(语言-javascript)
- ¥15 无法使用此凭据登录,因为你的域不可用,如何解决?(标签-Windows)
- ¥15 yolov9的训练时间
- ¥15 二叉树遍历没有报错但无法正常运行
- ¥15 在linux系统下vscode运行robocup3d上场球员报错
- ¥15 Python语言实验
- ¥15 SAP HANA SQL 增加合计行
- ¥20 用C#语言解决一个英文打字练习器,有偿
- ¥15 srs-sip外部服务 webrtc支持H265格式
- ¥15 在使用abaqus软件中,继承到assembly里的surfaces怎么使用python批量调动