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的入侵检测:基于机器学习,学习大量的正确的数据包和请求,一旦发现某个数据包与已经学习过的匹配度很低,则可疑。

相关推荐
敏编程4 小时前
一天一个Python库:jsonschema - JSON 数据验证利器
python
前端付豪5 小时前
LangChain记忆:通过Memory记住上次的对话细节
人工智能·python·langchain
碳基沙盒5 小时前
OpenClaw 多 Agent 配置实战指南
运维
databook5 小时前
ManimCE v0.20.1 发布:LaTeX 渲染修复与动画稳定性提升
python·动效
花酒锄作田18 小时前
使用 pkgutil 实现动态插件系统
python
前端付豪21 小时前
LangChain链 写一篇完美推文?用SequencialChain链接不同的组件
人工智能·python·langchain
曲幽1 天前
FastAPI实战:打造本地文生图接口,ollama+diffusers让AI绘画更听话
python·fastapi·web·cors·diffusers·lcm·ollama·dreamshaper8·txt2img
老赵全栈实战1 天前
Pydantic配置管理最佳实践(一)
python
阿尔的代码屋1 天前
[大模型实战 07] 基于 LlamaIndex ReAct 框架手搓全自动博客监控 Agent
人工智能·python
AI探索者2 天前
LangGraph StateGraph 实战:状态机聊天机器人构建指南
python