您现在的位置是:网站首页> 编程资料编程资料
Python selenium get_cookies获取cookie不全的解决方案_python_
2023-05-25
370人已围观
简介 Python selenium get_cookies获取cookie不全的解决方案_python_
一、场景
浏览器访问淘宝,再访问天猫,继续访问1688......
此时,浏览器中的cookie是什么状态?
显然,包含上述3个网站的所有cookie

二、此时,若通过selenium get_cookies()方法,能获取到浏览器所有cookie吗?
答案显然是不能的(webdriver安全考虑),此方法只能获取当前请求域名下的所有cookie
故访问天猫或1688会登录失败。
那可以通过什么方式,将浏览器所有cookie获取?
方案一:基于浏览器内核,打造属于自己的浏览器,解除限制
方案二:挂代理,Fiddler,mitmproxy等
方案三:分别请求对应域名,获取所有cookie(推荐,笔者首创)
三、样例代码
lmdd_url = f'{self.root_lmdd_url}/seller/dashboard/plan/order' self.chrome.get(lmdd_url) cookie_list = self.chrome.get_cookies() self.chrome.get(self.root_lmdd_api_url) cookie_list_api = self.chrome.get_cookies() cookie_list.extend(cookie_list_api) self.update_session_cookie(cookie_list)补充:selenium通过add_cookie()添加cookie
selenium通过add_cookie()添加cookie,再次访问网站时,服务器直接读取浏览器cookie
第一次登陆 手动输入用户名密码
# -*- coding:utf-8 -*- from selenium import webdriver from time import sleep driver = webdriver.Firefox() driver.get('http://www.baidu.com') sleep(2) driver.find_element_by_xpath('//*[@id="u1"]/a[7]').click() driver.add_cookie({'name':'userName','value':'youname'}) driver.add_cookie({'name':'password','value':'youpassword'}) sleep(30) driver.get('http://www.baidu.com') driver.find_element_by_id('kw').send_keys('selenium')总结
到此这篇关于Python selenium get_cookies获取cookie不全解决的文章就介绍到这了,更多相关Python selenium get_cookies获取cookie内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
您可能感兴趣的文章:
相关内容
- python3中join和格式化的用法小结_python_
- python中os库的函数使用_python_
- 详解Python使用OpenCV如何确定一个对象的方向_python_
- 一文带你了解Python枚举类enum的使用_python_
- Django中数据在前后端传递的方式之表单、JSON与ajax_python_
- 非常详细的Django连接mysql数据库步骤记录_python_
- Python中Django与Echarts的结合用法图文详解_python_
- django第一个项目127.0.0.1:8000不能访问的解决方案详析_python_
- Django中ModelForm组件的简单配置与使用教程_python_
- 详解Python开发语言中的基本数据类型_python_
