这篇文章主要介绍“怎么使用python+selenium实现扫码免密登录”,在日常操作中,相信很多人在怎么使用python+selenium实现扫码免密登录问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希
这篇文章主要介绍“怎么使用python+selenium实现扫码免密登录”,在日常操作中,相信很多人在怎么使用python+selenium实现扫码免密登录问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么使用python+selenium实现扫码免密登录”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!
一、需求描述
web 自动化测试/python爬虫往往会遇到扫码登录的情况,不是所有的网站都支持用户密码登录,遇到这种扫码登录的情况会阻碍我们自动化测试/爬虫的进行,所有为了可以顺畅的进行我们的需求,在进行自动化或者爬虫前我们首先要解决扫码登录的问题,下面讲解如何实现扫码免密登录。
二、首先扫码登录获取cookies保存到本地未后面免密登录做准备
具体实现代码如下:
- def get_cookies():
- # 首先获取cookies保存至本地
- driver = webdriver.Chrome('/Users/xxx/Documents/python/pack/chromedriver/chromedriver')
- page_url = 'https:/xxx/38268919/bugtrace/buglists/query/1/created/desc?query_token=20220706291334df28c613a85aa589f04376d034'
- driver.get(page_url)
- driver.maximize_window()
- # 进行扫码登录
- time.sleep(20)
- # 获取列表形式的cookies
- cookies = driver.get_cookies()
- # 转换成字符串保存
- jsonCookie = json.dumps(cookies)
- # 保存到txt文件
- with open('cookies.txt','w') as f:
- f.write(jsonCookie)
- print('cookies保存成功!')
三、初始化浏览器
- def browser_initial():
- driver = webdriver.Chrome('/Users/xxx/Documents/python/pack/chromedriver/chromedriver')
- page_url = 'https://xxx/38268919/bugtrace/buglists/query/1/created/desc?query_token=20220706291334df28c613a85aa589f04376d034'
- driver.get(page_url)
- driver.maximize_window()
- return driver
四、获取本地保存的cookies实现登录
代码实现如下
- def login(driver):
- with open('cookies.txt','r',encoding='utf8') as f:
- cookies = json.loads(f.read())
- # 给浏览器添加cookies
- for cookie in cookies:
- cookie_dict = {
- 'domain': '.tapd.cn',
- 'name': cookie.get('name'),
- 'value': cookie.get('value'),
- "expiry": 1658386136,
- 'path': '/',
- 'httpOnly': True,
- 'Secure': True
- }
- # print(cookie_dict)
- driver.add_cookie(cookie_dict)
- # 刷新网页,cookies才会成功
- driver.refresh()
- if __name__ =='__main__':
- driver=browser_initial()
- login(driver)
到此,关于“怎么使用python+selenium实现扫码免密登录”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注恰卡网网站,小编会继续努力为大家带来更多实用的文章!
本站部分文章来自网络或用户投稿,如无特殊说明或标注,均为本站原创发布。涉及资源下载的,本站旨在共享仅供大家学习与参考,如您想商用请获取官网版权,如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。