Python+Selenium实现web自动化跳过登录

49 篇文章 2 订阅
12 篇文章 0 订阅

Web自动化跳过登录

背景

自动化模拟登录,遇到图形验证码或者动态验证码时,代码操作复杂。该怎么跳过登录?

思路

研究文档发现,selenium有add_cookie()方法

方法

driver.add_cookie({'name': k, 'value': v})

其中k,v对应一条cookie的键值

代码

from selenium import webdriver
from selenium.webdriver.common.keys import Keys
import time, sys, io

driver = webdriver.Chrome(executable_path="C:/Program Files (x86)/Google/Chrome/Application/chromedriver.exe")
driver.get("http://example.com/index?argv=1")
assert "页面标题" in driver.title
driver.maximize_window()

# __IDENTIFY__=1951aca300a50f64a26a8ed5e970f4c3
# ttdd_session_id=040f57dbd50492b70c0a5322f82ff9f9f8212cc969367b366f9ecffc3fe5999b
cookies = dict(__IDENTIFY__='1951aca300a50f64a26a8ed5e970f4c3', ttdd_session_id='040f57dbd50492b70c0a5322f82ff9f9f8212cc969367b366f9ecffc3fe5999b')
for k, v in cookies.items():
    driver.add_cookie({'name': k, 'value': v})

time.sleep(1)
driver.refresh()
# driver.get("http://example.com/index?argv=1")  # why not work?
time.sleep(5)
# 点击 元素
e = driver.find_element_by_xpath('/html[1]/body[1]/div[1]/div[3]/div[1]/div[1]/ul[1]/li[9]/a[1]/span[1]')  # use ChroPath to locate element
e.click()
time.sleep(2)
# 点击 元素
e = driver.find_element_by_xpath('/html[1]/body[1]/div[1]/div[3]/div[1]/div[1]/ul[1]/li[9]/ul[1]/li[7]/a[1]/span[1]')  # use ChroPath to locate element
e.click()
time.sleep(2)
# 输入文本
# e= driver.find_element_by_xpath('/html[1]/body[1]/div[1]/div[3]/div[2]/div[1]/div[2]/form[1]/div[1]/input[1]')
e = driver.find_element_by_xpath("//input[contains(@placeholder,'只支持item_id搜索')]")
e.click()
e.send_keys(538)
time.sleep(2)
# 点击 元素
e = driver.find_element_by_xpath("//button[contains(@class,'btn btn-sm green table-group-action-submit')]")
e.click()
time.sleep(2)   
# 查找是否有 元素
try:
    e = driver.find_element_by_xpath("//tr[1]//td[14]//a[2]")
    print('找到元素')
except:
    print('无此元素')


# 遍历表格
cells = []
trlist = driver.find_elements_by_tag_name('tr')
for row in trlist:
    tdlist = row.find_elements_by_tag_name('td')
    print('列表行数', tdlist)
    row_list = []
    for col in tdlist:
        row_list.append(col.text)
        print(col.text + '\t', end= '')
    print('\n')
    cells.append(row_list)
print('*' * 200)
print(cells)

time.sleep(10)
driver.close() # 关闭当前tab
time.sleep(5)
driver.quit() # 关闭浏览器所有tab

总结

1、添加多条cookie,可用for循环
2、使用by_tag_name方法对表格内容进行遍历
3、cookie抓包可用fiddler,或者浏览器F12功能
4、元素定位可用Chrome插件ChroPath
5、WebDriver下载地址: https://selenium.dev/documentation/en/webdriver/driver_requirements/#quick-reference
6、WebDriver路径添加到系统Path

  • 0
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
### 回答1: Selenium 是一个用于 Web 自动化的工具,它可以通过各种语言,如 Python、Java、C# 等,来控制网页的操作。 使用 PythonSelenium 可以写出自动化Web 脚本,用于模拟人的行为,如打开浏览器、访问网页、点击链接、填写表单等。 通过使用 Selenium 库和 Python 语言,开发者可以快速地编写出完整的 Web 自动化测试用例,帮助验证 Web 应用的正确性和稳定性。 ### 回答2: Python Selenium是一个用于编写Web自动化脚本的工具。它可以通过模拟用户在浏览器中的操作来实现自动化测试和数据爬取等任务。 使用Python Selenium,你可以打开一个浏览器窗口,访问一个指定的网页,并模拟点击、输入文本等操作。例如,你可以用它来完成登录一个网站、填写表单、点击按钮等操作。 通过Python Selenium,你可以自动化执行一系列重复性的任务,从而提高效率并节省时间。例如,你可以写一个脚本来定期检查一个网页上是否有更新,并在有更新时发送通知。 另外,Python Selenium还可以用来爬取网页数据。你可以使用它来自动打开网页、提取页面上的信息,并将其保存到本地或者数据库中。这在进行数据分析、监控等任务时特别有用。 Python Selenium提供了丰富的API和功能,可以让你灵活地进行定制和扩展。你可以设置浏览器选项、处理弹窗、执行JavaScript代码等等。此外,它还可以与其他Python库和工具结合使用,例如BeautifulSoup用于解析网页内容、Pandas用于数据处理等。 总之,Python Selenium是一个强大且灵活的工具,可用于编写Web自动化脚本。无论是进行自动化测试、数据爬取还是其他Web相关任务,它都可以帮助你自动化完成一些繁琐的操作,提高效率和准确性。
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值