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解析进行其他处理,具体参考下面的
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥20 我想使用一些网络协议或者部分协议也行,主要想实现类似于traceroute的一定步长内的路由拓扑功能
- ¥30 深度学习,前后端连接
- ¥15 孟德尔随机化结果不一致
- ¥15 apm2.8飞控罗盘bad health,加速度计校准失败
- ¥15 求解O-S方程的特征值问题给出边界层布拉休斯平行流的中性曲线
- ¥15 谁有desed数据集呀
- ¥20 手写数字识别运行c仿真时,程序报错错误代码sim211-100
- ¥15 关于#hadoop#的问题
- ¥15 (标签-Python|关键词-socket)
- ¥15 keil里为什么main.c定义的函数在it.c调用不了