Selenium系列(21) - Cookie操作和源码解读

如果你还想从头学起Selenium,可以看看这个系列的文章哦!

https://www.cnblogs.com/poloyy/category/1680176.html

 

其次,如果你不懂前端基础知识,需要自己去补充哦,博主暂时没有总结(虽然我也会,所以我学selenium就不用复习前端了哈哈哈...)

 

为什么需要Cookie操作

有时候我们需要验证浏览器中Cookie是否正确,因为基于真实Cookie的测试是无法通过白盒和集成测试进行的

测试某些网站若需要先登录,可以直接通过接口去登录,把返回的Cookie存起来,相当于UI自动化上的免登录了,除开了不必要的登录操作

 

有哪些Cookie操作

  • get_cookies(): 获得所有cookie信息

  • get_cookie(name): 返回字典的key=name的cookie信息

  • add_cookie(cookie_dict) : 添加cookie

  • delete_cookie(name):删除cookie信息name是要删除的cookie的名称

  • delete_all_cookies(): 删除所有cookie信息

 

直接上代码

# 浏览器
driver = webdriver.Chrome("../resources/chromedriver.exe")
driver.get("https://px.seewo.com/product")

# 获得网站的Cookies信息
cookie = driver.get_cookies()

# 将获得Cookies的信息打印
print(cookie)

# 发起登录请求

# 登录后存放的两个token,需要添加到Cookie中去
cookie_list = {}
cookies["px-token"] = exchangedToken
cookies["x-token"] = token

# 添加Cookie
for cookie_ in cookies.items():
    driver.add_cookie({'name': cookie_[0], 'value': cookie_[1], 'path': '/', 'httpOnly': True, 'secure': True})

# 再次打印Cookie
print(driver.get_cookies())

# 执行UI自动化操作
# ......
# ......

# 发起退出登录请求

# 删除某个Cookie
driver.delete_cookie("x-token")

# 删除所有Cookie
driver.delete_all_cookies()

# 浏览器关闭
driver.quit()

可以看看, get_cookies()  返回的数据是什么样的

[{'domain': '.training.test.seewo.com', 'httpOnly': False, 'name': 'Hm_lpvt_b195036baa8d1a75b4e9572ee8593bdd', 'path': '/', 'secure': False, 'value': '1586141195'}, {'domain': '.training.test.seewo.com', 'expiry': 1617677195, 'httpOnly': False, 'name': 'Hm_lvt_b195036baa8d1a75b4e9572ee8593bdd', 'path': '/', 'secure': False, 'value': '1586141195'}, {'domain': 'training.test.seewo.com', 'expiry': 1586227594.128949, 'httpOnly': True, 'name': 'connect.magick', 'path': '/', 'secure': False, 'value': 's%3AyLzNW4COEHLgiVSDtpv1pcUKzKmsMpoj.5mQxyZpM9kUEdsqXTyCFoht%2F3avDA20S%2Foz5jB52G7U'}]

 

源码解读

Selenium系列(21) - Cookie操作和源码解读_第1张图片

 

知识点

  • get_cookie:从get_cookies()返回的Cookie列表中,循环判断,获取对应的Cookie
  • add_cookie:传入dict对象,有两个必传key值:name、vlaue;五个可选key值:path、domain、secure、expiry、httpOnly;可以看到你的字典对象不能乱传key,否则会报错
  • delete_cookie:传入的是Cookie的name值

 

 

你可能感兴趣的:(Selenium系列(21) - Cookie操作和源码解读)