python+selenium+Chrome Web自动化测试进阶学习2

Selenium:
对百度
1、使用Chrome打开浏览器
2、最大化页面,进入登录页面
3、输入用户名、密码
4、点击登陆按钮
5、验证登录后的url地址是否正确

po模式:页面对象模型(PO)是一种设计模式,用来管理维护一组页面元素的对象库. 是这样解释的。具体有兴趣的可以再百度。
我不知道我是不是po模式。
selenium有几种常用定位方式,id,name,class_name,css
_selector等,还有xpath,这个题目说是要求2种以上的元素定位方式,无奈我写完之后竟然无法找到,我干脆全用xpath了···
为了成功。

from selenium import webdriver
import time
from selenium.webdriver.support import  expected_conditions as EC
driver=webdriver.Chrome()
driver.get("https://www.baidu.com")
//最大化窗口
driver.maximize_window()
time.sleep(2)
//找到页面上登录的按钮
driver.find_element_by_xpath("/html/body/div[1]/div[1]/div[4]/a").click()
#usernamelogin=driver.find_elements_by_css_selector('p.tang-pass-footerBarULogin')[0]
#usernamelogin.click()
time.sleep(2)
//打开登录的界面后选择用户名登录
driver.find_element_by_xpath("//*[@id='TANGRAM__PSP_11__footerULoginBtn']").click()
time.sleep(1)
//输入用户名
driver.find_element_by_xpath("//*[@id='TANGRAM__PSP_11__userName']").send_keys("用户名")
time.sleep(2)
//输入密码
driver.find_element_by_name("password").send_keys("密码")
time.sleep(2)
//定位“登录”按钮并点击提交
driver.find_element_by_xpath("//*[@id='TANGRAM__PSP_11__submit']").click()
time.sleep(2)
'''
username=driver.find_element_by_id('TANGRAM__PSP_11__userName')
username.send_keys('username')
time.sleep(1)
password=driver.find_elements_by_id('TANGRAM__PSP_11__password')
password.send_keys('pwd')
time.sleep(1)
submit=driver.find_elements_by_id('TANGRAM__PSP_11__submit')
submit.click()
'''
//发现会有个验证码验证,所以要写一个跳过验证码
driver.add_cookie({'name':'BAIDUID','value':'13D7EE1B22B3D91D2FBCB797812A92D5:FG=9'})
driver.add_cookie({'name':'BDUSS','value':'ctYjRpR21qdkpwcXZjUnE4ektmeUkzbHJhc2tsanlBOFVwWEIzNGNHaDVOeVpoRVFBQUFBJCQAAAAAAAAAAAEAAAAKQZE5seWw18PnxMvO4cTQyfEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAioo'})
driver.refresh() #刷新页面查看登录效果
time.sleep(4)
//验证登录之后跳转的是不是百度页面
title=EC.title_is(u'百度一下,你就知道')
print(title(driver))
//关闭浏览器
driver.quit()

有以下几点是需要学习的:
1.如何定位元素
定位xpath元素是这样的
进入控制台之后 点击小箭头,选中登录键,对应的代码就是蓝色选中区域

在这里插入图片描述
右键选择copy xpath
在这里插入图片描述
之后打开sublime粘贴一下
发现是这样的
//*[@id=“s-top-loginbtn”]
在这里插入图片描述
代码里写的是full xpath,是这样的
/html/body/div[1]/div[1]/div[4]/a
这两种xpath都可以定位到的
2.关于cookie的抓取
使用你的用户名和密码先登录一下
之后f12抓包后台抓取cookie
在这里插入图片描述
拷贝之后写到代码中
BAIDUID和BDUSS标识了一个人的身份
为什么要选择BDUSS,我看到如下解释:
目前百度内部采用的方法是:
使用 wise 部门提供的一套 wise 登录代理服务(HTTP 接口) 。
该代理服务的实现原理是: wise 登录代理负责分配并记录用户BDUSS,同时返回 md5 加密的 ssid,并携带到 url 参数中向后传递。 当用户刷新页面时, 由产品线 ui 根据 url 中的 ssid 字段向 wise 请求 BDUSS, 利用返回 BDUSS 同 passport session 服务交互获取用户信息;
最后总结问题:
为什么id和name还有classname定位不到呢?

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值