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)

Firefox的驱动:geckodriver.exe

浏览器和驱动出现不兼容时试一试:

googlechromelabs.github.io/chrome-for-testing/known-good-versions-with-downloads.json

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

相关推荐
王小王-12311 分钟前
基于Python的车联网数据聚合与可视化分析平台设计与实现
python·车联网·新能源汽车·车联网聚合分析
C语言小火车16 分钟前
嵌入式Linux应用开发技术栈完全指南
linux·运维·服务器
IT WorryFree26 分钟前
FortiGate 排错常用OID速查表(含Trap OID+轮询OID)
运维·网络
m0_7381207227 分钟前
渗透测试基础——基于Docker的Rsync服务靶场搭建与原理讲解
运维·服务器·网络·安全·web安全·docker·容器
MXsoft61836 分钟前
**运维监控技术演进:从数据采集到智能运维的****技术提升**
运维
叫我:松哥38 分钟前
基于Flask框架的校园二手书籍交易平台,注重校园场景的特殊需求,通过学号认证保障用户真实性
后端·python·sqlite·flask·bootstrap
namexingyun1 小时前
开源前端生态如何成为 AI UI 生成的“燃料“:shadcn/ui、Tailwind CSS、Storybook 技术价值全解剖
java·前端·人工智能·python·ui·开源·ai编程
通信仿真爱好者1 小时前
第【17】期--考虑硬件损伤和不完美CSI的RIS-MISO系统的深度强化学习联合优化-python完整代码+参考文献
python·深度强化学习·ris
装不满的克莱因瓶1 小时前
自然语言处理常见任务——从文本理解到生成式AI的完整任务体系
人工智能·pytorch·python·深度学习·ai·自然语言处理
12点一刻1 小时前
Hermes Agent 与 Superpowers 框架的区别?
运维·服务器