web自动化特殊场景:
1、浏览器复用场景(chrome浏览器)
2、使用cookie完成页面的自动登录
3、
浏览器复用场景(chrome浏览器)
浏览器复用步骤:
1、进入chrome浏览器的安装路径,并在该路径下打开cmd命令行,输入以下命令:
chrome --remote-debugging-port=9222
这个命令相当于打开了chrome的一个调试网页,通过这种方式打开的网页不要关闭,
2、通过python代码实现浏览器打开时直接复用步骤1中打开的调试网页,代码在定义webdriver变量时传入了options参数
chrome_args = webdriver.ChromeOptions()
chrome_args.debugger_address = "127.0.0.1:9222"
self.driver = webdriver.Chrome(options=chrome_args)
注意:在执行代码前需要先把所有chrome网页关闭,然后重新打开调试网页,再运行复用浏览器的代码;如果之前有打开非调试的chrome网页,会导致代码运行卡住
3、如果你的网页需要进行扫码登录,那么你可以先在调试浏览器网页中进行登录,使用步骤2的代码复用浏览器后,就直接可以进行元素定位,这样就可以省略掉登录的步骤了
使用cookie完成页面的自动登录
cookie:是浏览器的一个数据缓存或者是身份标识,在cookie没有失效的情况下,服务器可以使用浏览器的cookie数据实现用户的自动登录,cookie的有效期是服务器来决定的
selenium提供了一个可以直接获取当前页面的cookie信息的方法,只要把获取到的cookie数据保存下来,然后复用该cookie就能实现网页的自动登录
1、首先要自己登录网页后,通过代码去获取网页的cookie信息,并保存到json文件中
class TestLogin:
def setup_method(self):
chrome_args = webdriver.ChromeOptions()
chrome_args.debugger_address = "127.0.0.1:9222"
self.driver = webdriver.Chrome(options=chrome_args)
def test_getcookies(self):
# 使用浏览器调试网页登录后,直接获取网页的cookie信息
cookies = self.driver.get_cookies()
# 将获取到的cookie信息写入到cookies.json文件中
with open("cookies.json", "w") as f:
json.dump(cookies, f)
2、从json文件中读取cookie信息,实现网页的自动登录
def test_login(self):
# 先打开需要登录的网页(未登录的状态下)
self.driver.get("https://work.weixin.qq.com/")
# 读取cookie信息
with open("cookies.json", "r") as f:
cookies = json.load(f)
# 通过add_cookie方法注入cookie,add_cookie方法在注入之前要打开需要注入的网页,就是第一行代码
for cookie in cookies:
self.driver.add_cookie(cookie)
# 注入后,重新打开登录后的页面
self.driver.get("https://work.weixin.qq.com/wework_admin/frame")
self.driver.find_element_by_id("menu_contacts").click()
sleep(3)