使用这两个组件,.NET 网页截图就这么简单

共 3567字,需浏览 8分钟

 ·

2023-08-25 05:31

    前段时间有个需求,需要实现打开某个页面,在修改页面前截取图片保存留底。在github找了两个开源软件方案,一个是PuppeteerSharp另外一个是Selenium.WebDriver。两者都是可以实现无头模式的网页抓取工具,使用也非常简单。下面介绍这两个开源的组件以及他们抓取图片的案例。

1、PuppeteerSharp

PuppeteerSharp 是一个用于在 .NET 平台上控制无头(Headless) Chrome 浏览器的库。它允许开发者通过编程方式模拟浏览器行为,执行网页操作,截取网页截图,获取网页内容,可以把网页转换成PDF等等。PuppeteerSharp 是 Puppeteer 在 .NET 环境中的等效实现,Puppeteer 是由 Google 提供的一个用于控制无界面浏览器 Chrome 的工具。

抓取网页图片案例

      
        
          //初始化浏览器
        
      
      
        await new BrowserFetcher().DownloadAsync(BrowserFetcher.DefaultChromiumRevision);
      
      
        var browser = await Puppeteer.LaunchAsync(new LaunchOptions
      
      
        {
      
      
            Headless = true//是否隐藏浏览器,true为隐藏
      
      
        });
      
      
        
          // 创建一个页面对象
        
      
      
        var page = await browser.NewPageAsync();
      
      
        
          // 导航到指定的URL
        
      
      
        await page.GoToAsync("https://www.baidu.com");
      
      
        
          //截图     FullPage是全屏
        
      
      
        await page.ScreenshotAsync("test001.png",new ScreenshotOptions() { FullPage=true });
      
    
具体大家可以参考github地址的官方使用说明。 github地址:github.com/hardkoded/puppeteer-sharp


2、Selenium.WebDriver

Selenium.WebDriver 是一个用于自动化浏览器操作的 .NET 库,它提供了一组 API,允许开发者模拟用户在浏览器中的行为,从而进行自动化测试、数据抓取、网页操作等操作。Selenium 是一个广泛使用的工具,用于自动化浏览器操作和测试,而 Selenium.WebDriver 是其在 .NET 平台上的一个实现。同时Selenium.WebDriver也支持无头模式。

抓取网页图片案例

      
           public void WebDriverGetPic()
      
      
                {
      
      
                    // 初始化 ChromeDriver
      
      
                    var chromeOptions = new ChromeOptions();
      
      
                    chromeOptions.AddArgument("--headless"); // 使用无头模式,即不显示浏览器界面
      
      
                    string currentDirectory = Environment.CurrentDirectory+ "\\selenium-manager\\windows\\";
      
      
                    chromeOptions.BinaryLocation = "selenium-manager.exe";
      
      
                    using (var driver = new ChromeDriver(chromeOptions))
      
      
                    {
      
      
                        // 要截取的网页的 URL
      
      
                        var url = "https://www.baidu.com"; // 替换为你想要截取的网页的 URL
      
      
        
          
// 打开网页 driver.Navigate().GoToUrl(url);
// 等待网页加载完成 System.Threading.Thread.Sleep(5000); // 这里等待 5 秒,你可以根据实际情况调整等待时间
// 截取整个网页的截图 var screenshot = ((ITakesScreenshot)driver).GetScreenshot();
// 保存截图为文件 screenshot.SaveAsFile("screenshot.png", ScreenshotImageFormat.Png); } }
具体大家可以参考githu b 地址的官方使用说明 github地址:github.com/SeleniumHQ/selenium


结语

本文介绍了两种截图的.NET库,在使用上他们都依赖Chrome浏览器包,都支持无头浏览。功能上来说PuppeteerSharp侧重网页内容的处理,而Selenium.WebDriver侧重于自动化测试。缺点是依赖浏览器。 大家用过那些.NET的网也截图库,最好不依赖浏览器的库,欢迎大家在文章下方留言和吐槽,共同分析和讨论.NET的网也截图这个话题。

版权声明:本文来源于网友收集或网友供稿,仅供学习交流之用,如果有侵权,请转告小编或者留言,本公众号立即删除。


    

关注公众号DotNet开发跳槽    

      

9f7be7fe28455b97a7ee6254f688d5da.webp

3ca5d99977cbb01df352f0c2b7a96e6a.webp

09c054bcd748ffe91f4b80e327bc4df3.webp

点在看

浏览 18
点赞
评论
收藏
分享

手机扫一扫分享

分享
举报
评论
图片
表情
推荐
点赞
评论
收藏
分享

手机扫一扫分享

分享
举报