20.基于Selenium实现界面自动化控制

一、为什么需要操作Web界面

1、通常情况下,网络安全相关领域,更多都是偏重于协议和通信。

2、但是,如果协议通信过程被加密或者无法了解其协议构成,是无法直接通过协议进行处理。此时,可以考虑模拟U操作,进而实现相对应的部分功能。

二、模拟UI操作的原理

1、运行被操作的程序,使其界面出现。

2、找到被操作的界面元素(方法一:基于元素的特征进行识别,方法二:图像识别和对比,openc)

3、对其进行操作:输入、单击、右键等

4、对操作后的结果进行验证,确认操作是成功的

三、基于Selenium实现

在终端运行以下命令,确保 selenium 安装在当前 Python 环境:

复制代码
pip install selenium

如果要操作windows元素,则使用库uiautomation,如果要处理移动端,appium

ChromeDriver 下载地址:

chromedriver.storage.googleapis.com/index.html

Chrome for Testing availabilityhttps://googlechromelabs.github.io/chrome-for-testing/known-good-versions-with-downloads.json) ![1768394942076](https://i-blog.csdnimg.cn/img_convert/7f2853224393788448f5fe9afcbbf4ac.png) Firefox的驱动:geckodriver.exe 浏览器和驱动出现不兼容时试一试: [googlechromelabs.github.io/chrome-for-testing/known-good-versions-with-downloads.json](https://googlechromelabs.github.io/chrome-for-testing/known-good-versions-with-downloads.json) ![1768401752019](https://i-blog.csdnimg.cn/img_convert/2e2ed005539eb946cedd5a00ec7fa261.png) ```python from selenium import webdriver from selenium.webdriver.chrome.options import Options from selenium.webdriver.common.by import By import time chrome_options = Options() # 1. 指定driver和浏览器路径 chrome_options.executable_path = 'D:/CyberSecurity/tools/chromedriver-win64/chromedriver.exe' chrome_options.binary_location = 'D:/BaiduNetdiskDownload/Chrome/App/chrome.exe' # # # 2. 增加关键启动参数(解决空白页/加载异常) chrome_options.add_argument("--no-sandbox") # 禁用沙箱模式(Windows下部分环境需要) # chrome_options.add_argument("--disable-dev-shm-usage") # 避免临时目录内存不足 chrome_options.add_argument("--start-maximized") # 启动时最大化窗口 # chrome_options.add_experimental_option("excludeSwitches", ["enable-automation"]) # 关闭自动测试提示 # 启动浏览器并访问页面 driver = webdriver.Chrome(options=chrome_options) driver.get('http://192.168.102.131:8080/woniusales/') # 利用DOM的识别机制,去识别和操作界面元素 # 通过ID定位"用户名输入框",并输入admin driver.find_element(By.ID, "username").send_keys("admin") time.sleep(1) driver.find_element(By.ID, "password").send_keys("admin123") time.sleep(1) driver.find_element(By.XPATH,"//*[@id='verifycode']").send_keys("0000") time.sleep(1) driver.find_element(By.XPATH,"/html/body/div[4]/div/form/div[6]/button").click() time.sleep(2) # 刷新 driver.refresh() # driver.forward() # print(driver.get_cookies()) if '请扫描商品条码' in driver.page_source: print("登录成功。") else: print('登录失败。') time.sleep(5) # 等待观察页面是否加载 ``` 网络安全的AI应用:入侵检测 传递的入侵检测:基于特征,某个流量或请求,存在一些可疑的特征时,进行预警或防护 基于AI的入侵检测:基于机器学习,学习大量的正确的数据包和请求,一旦发现某个数据包与已经学习过的匹配度很低,则可疑。

相关推荐
lifewange16 分钟前
主流性能诊断工具
测试工具
DianSan_ERP27 分钟前
如何通过抖店订单接口实现订单状态管理与履约自动化?
运维·自动化
旦莫1 小时前
AI驱动的纯视觉自动化测试:知识库里应该积累什么知识内容
人工智能·python·测试开发·pytest·ai测试
b***25111 小时前
18650电池点焊机:电阻焊技术如何决定电池组的成败|深圳比斯特自动化
运维·自动化
原来是猿1 小时前
网络计算器:理解序列化与反序列化(中)
linux·运维·服务器·网络·tcp/ip
前端老曹1 小时前
Docker 从入门到放弃:完整指南
运维·docker·容器
知识领航员2 小时前
蘑兔AI音乐深度实测:功能拆解、实测表现与适用场景
java·c语言·c++·人工智能·python·算法·github
AOwhisky2 小时前
虚拟化技术学习笔记
linux·运维·笔记·学习·虚拟化技术
rabbit_pro3 小时前
Docker compose部署Ollama使用模型
linux·运维·docker
如何原谅奋力过但无声3 小时前
【灵神高频面试题合集06-08】反转链表、快慢指针(环形链表/重排链表)、前后指针(删除链表/链表去重)
数据结构·python·算法·leetcode·链表