如何在Visual Studio和 .NET 7中使用C#配置代理服务器进行网页抓取,并使用HtmlAgilityPack进行HTML解析

立即注册获得充值奖励,并开始自己的项目。亮数据-网络IP代理及全网数据一站式服务商

本项目演示了如何在 Visual Studio 和 .NET 7 中使用 C#配置代理服务器进行网页抓取,并使用 HtmlAgilityPack 进行 HTML 解析。通过使用代理服务器的 IP 地址,代理可以在网页抓取时保护您的数字身份,从而绕过 IP 封禁和地域限制。

前置条件

配置本地代理

  • 下载并安装 mitmproxy。
  • 通过命令 mitmproxy 启动 mitmproxy。

网页抓取设置

ProxyHttpClient - 用于配置 HttpClient 实例通过指定的代理服务器发送请求。
ProxyRotator - 管理一组代理,并提供随机选择代理的方法以处理每个网络请求。通过随机化在多个代理之间发送请求,可以有效减少被检测及 IP 封禁的风险。

isLocal 设置为 True 时,会使用本地 mitmproxy 代理;若设置为 False,则会使用公共代理 IP。
ProxyChecker - 用于验证代理服务器列表。当您使用 GetWorkingProxies 方法并传入代理 URL 列表时,该方法会通过异步调用 CheckProxy 来检查每个代理的状态,并把可以正常工作的代理收集到 workingProxies 列表中。在 CheckProxy 方法中,您会为每个代理 URL 建立一个 HttpClient,向 http://www.google.com 进行测试请求,并使用信号量(semaphore)安全地记录进度。
IsProxyWorking 方法通过检查响应的状态码,确认代理是否可用,如果可用则返回 true。此类能够帮助您从给定的代理列表中识别出可用的代理。
WebScraper - 封装了网页抓取功能。当您调用 ScrapeData 方法时,需要传入一个 ProxyRotator 实例和目标 URL。接下来会使用 HttpClient 异步地向该 URL 发送 GET 请求,获取 HTML 内容,并用 HtmlAgilityPack 库进行解析。然后使用 XPath 查询从特定 HTML 元素中定位并提取链接及对应的标题。如果找到任何文章链接,就会打印它们的标题和完整 URL;否则会输出一条提示消息,说明没有找到链接。

使用 Bright Data 代理

  • 注册 Bright Data 并创建 住宅代理
  • WebScrapeBrightdata 项目的 appsettings.json 文件中更新您的凭证。

运行应用程序

  • 使用命令 dotnet builddotnet run -- --url https://www.wikipedia.org/ 编译并执行程序,运行后会显示抓取到的维基百科文章标题和链接。
    Bright Data 的代理服务 为 C# 的匿名和高效网页抓取提供可扩展的解决方案,帮助规避 IP 封禁。通过本教程,您可以学习如何在网页抓取项目中集成代理服务器,并遵循最佳实践来确保数据采集的可靠性。
相关推荐
向宇it1 小时前
【blender小技巧】Blender导出带贴图的FBX模型,并在unity中提取材质模型使用
开发语言·unity·c#·游戏引擎·blender·材质·贴图
大模型铲屎官4 小时前
# Unity动画控制核心:Animator状态机与C#脚本实战指南 (Day 29)
c语言·unity·c#·游戏引擎·游戏开发·动画控制·animator状态机
安全菜鸟4 小时前
DeepSeek 接入 Word 完整教程
开发语言·c#·word
vil du4 小时前
c# AI编程助手 — Fitten Code
开发语言·c#·ai编程
努力长头发的程序猿5 小时前
UnityUI:Canvas框架获取鼠标悬浮UI
unity·c#
zxy28472253015 小时前
.NET MAUI教程2-利用.NET CommunityToolkit.Maui框架弹Toast
c#·.net·maui·toolkit.maui
追逐时光者6 小时前
Visual Studio 2022 v17.13新版发布:强化稳定性和安全,助力开发提效!
后端·.net·visual studio
liwulin05066 小时前
【WORD】批量将doc转为docx
开发语言·c#·word
Ring__Rain7 小时前
visual studio 常用的快捷键(已经熟悉的就不记录了)
c++·git·visual studio
WineMonk7 小时前
.NET WPF 控件类分层结构
.net·wpf