当前位置: 首页 > news >正文

Winform实现自制浏览器JavaScript注入

在这里插入图片描述

让我们一起走向未来

🎓作者简介:全栈领域优质创作者
🌐个人主页:百锦再@新空间代码工作室
📞工作室:新空间代码工作室(提供各种软件服务)
💌个人邮箱:[15045666310@163.com]
📱个人微信:15045666310
🌐网站:https://meihua150.cn/
💡座右铭:坚持自己的坚持,不要迷失自己!要快乐


在现代软件开发中,嵌入浏览器功能到桌面应用程序是一种常见需求。通过这种方式,应用程序能够展示网页内容,并与之进行动态交互。本文将详细探讨如何在WinForm应用程序中嵌入一个浏览器控件,然后在访问特定网页时,注入并执行JavaScript代码。整个文章将分为以下几个部分:

  1. 基础概念与工具选择
  2. WinForm中嵌入浏览器控件的方法
  3. JavaScript注入的基本原理
  4. 注入JavaScript代码并执行的具体实现
  5. 示例应用程序的构建与分析
  6. 安全性与常见问题
  7. 总结与展望

1. 基础概念与工具选择

在WinForm应用程序中嵌入浏览器的控件,可以使用多种工具。经典的选择是使用Microsoft的WebBrowser控件,但这在现代应用中已经渐渐被淘汰。随着浏览器技术的发展,CEF (Chromium Embedded Framework) 和 WebView2 (Microsoft Edge WebView2 Control) 成为了更好的选择。
WebBrowser控件:基于Internet Explorer内核,功能较为落后且不再维护。

在这里插入图片描述

  • CEF (Chromium Embedded Framework):一个简单的框架,用来嵌入基于Chromium的浏览器组件。

  • 在这里插入图片描述

  • WebView2:基于新Edge(Chromium)的浏览器控件,提供现代化的网页浏览体验。

选择合适的嵌入方式是开发的第一步,鉴于WebView2的简易性和现代化,这里选择它来进行后续的实现。


2. WinForm中嵌入浏览器控件的方法

2.1 准备开发环境

嵌入WebView2需要安装对应的开发工具和库:
在这里插入图片描述

  • Visual Studio 2019或更高版本。
  • .NET 5.0或更高版本。(可选)
  • Microsoft Edge WebView2的SDK。

安装WebView2 SDK,打开NuGet包管理器,并安装Microsoft.Web.WebView2包。

2.2 简单的嵌入示例

在WinForm项目中,拖拽一个Panel控件用于占位,然后在代码中加载WebView2控件:

using Microsoft.Web.WebView2.WinForms;
using Microsoft.Web.WebView2.Core;public partial class MainForm : Form
{public MainForm(){InitializeComponent();InitializeWebView2();}private async void InitializeWebView2(){var webView2 = new WebView2{Dock = DockStyle.Fill};panel1.Controls.Add(webView2);await webView2.EnsureCoreWebView2Async(null);webView2.CoreWebView2.Navigate("https://example.com");}
}

在这里插入图片描述

3. JavaScript注入的基本原理

WebView2提供了几种向网页注入JavaScript的手段,其核心是利用Context来执行JavaScript。执行JavaScript能够操控网页内容,或者与页面进行数据交互。

常用的方法是调用ExecuteScriptAsync,这个方法接受一个字符串,该字符串包含需要执行的JavaScript代码。

注入注意事项

注入外部代码时,需要特别注意浏览器的同源策略(Same-Origin Policy)和安全性,务必确保外部代码的来源安全。

await webView2.CoreWebView2.ExecuteScriptAsync("document.body.style.backgroundColor = 'lightblue';");

在这里插入图片描述


4. 注入JavaScript代码并执行的具体实现

4.1 动态脚本注入

在访问指定网页时,可以通过监听事件进行脚本注入。例如通过NavigationCompleted事件,检测网址并注入对应脚本:

webView2.CoreWebView2.NavigationCompleted += async (sender, args) =>
{if (webView2.Source.ToString() == "https://example.com"){string jsCode = "console.log('JavaScript injected successfully.');";await webView2.CoreWebView2.ExecuteScriptAsync(jsCode);}
};

在这里插入图片描述

4.2 基于条件的逻辑注入

为了实现复杂的交互逻辑,可以在软件中检测网页中的特定元素,并在元素存在时执行特定的操作。下面的代码展示了如何读取和修改网页中的元素内容:

string getElementContentScript = "document.querySelector('h1').innerText";
var result = await webView2.CoreWebView2.ExecuteScriptAsync(getElementContentScript);
Console.WriteLine($"Title of the page is {result}");

5. 示例应用程序的构建与分析

5.1 应用功能实现

在这里插入图片描述

以一个简单的应用为例,展示如何实现登录流程自动化以及特定用户交互的模拟。想象一个场景,您需要自动填充表单并提交:

string autoFillScript = @"document.querySelector('#username').value = 'testuser';document.querySelector('#password').value = 'password123';document.querySelector('form').submit();
";
await webView2.CoreWebView2.ExecuteScriptAsync(autoFillScript);
5.2 应用程序的整体架构
  • 前台界面:使用Panel容纳WebView2控件。
  • 后台服务:负责监听WebView2事件、管理注入逻辑。
  • 安全机制:确保注入脚本的安全性和合法性。

6. 安全性与常见问题

6.1 同源策略与CORS

JavaScript因同源策略需要进行跨域通信时,需要注意设置CORS允许的源。

6.2 防范XSS攻击

确保不执行不可信的外部输入,并对用户输入进行必要的校验与过滤。

6.3 常见Debug技巧
  • 使用浏览器开发者工具调试注入的JavaScript代码。
  • 在导航事件中打印日志以跟踪注入周期。

7. 总结与展望

通过WebView2嵌入浏览器控件并注入JavaScript,我们能够有效增强WinForms应用的功能。无论是实现简单的自动化任务,还是构建复杂的嵌入式浏览器应用,该方法均提供了一种现代化的解决方案。展望未来,随着Web技术的进步,嵌入式浏览器将更为普及,开发者也需要持续关注相关的技术更新与安全挑战。

在这里插入图片描述

http://www.lryc.cn/news/483694.html

相关文章:

  • 【工具插件类教学】在 Unity 中使用 iTextSharp 实现 PDF 文件生成与导出
  • javascript用来干嘛的?赋予网站灵魂的语言
  • Flutter Getx状态管理
  • 《成法》读书笔记
  • TensorFlow 2.0 环境配置
  • Ekman理论回归
  • 算法演练----24点游戏
  • 【学习心得】Python好库推荐——tiktoken
  • MacBook不额外安装软件,怎样投屏到安卓手机上?
  • flink sql + kafka + mysql 如何构建实时数仓
  • Go语言开发基于SQLite数据库实现用户表查询详情接口(三)
  • (11)(2.1.7) FETtec OneWire ESCs(二)
  • Springboot maven常见依赖、配置文件笔记
  • Ceph后端两种存储引擎介绍
  • C++入门基础知识140—【关于C++ 类构造函数 析构函数】
  • 基于标签相关性的多标签学习
  • macOS系统下使用SQLark连接达梦数据库
  • 爬虫如何解决短效代理被封的问题?
  • Jmeter基础篇(22)服务器性能监测工具Nmon的使用
  • Spring Boot 集成 RabbitMQ:消息生产与消费详解
  • JSON-RPC-CXX深度解析:C++中的远程调用利器
  • 【后端速成Vue】模拟实现翻译功能
  • 人脸识别技术:从算法到深度学习的全面解析
  • WPF学习之路,控件的只读、是否可以、是否可见属性控制
  • 植物神经紊乱不用怕,科学锻炼助你找回平衡✨
  • shell 100例
  • CSS教程(二)- CSS选择器
  • Ubuntu20.04 解决一段时间后键盘卡死 输入延迟很大的问题 ubuntu
  • http(s)接口设计注意事项
  • Font Awesome Web 应用图标