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

网站备案被注销了怎么办北京外企人力资源服务有限公司

网站备案被注销了怎么办,北京外企人力资源服务有限公司,网站手机pc同步,出入广州最新通知今天基于NodeHeadlessBrowser的浏览器自动化方案 什么是无头浏览器(Headless Browser)? 无头浏览器,就像是一个没有用户界面的浏览器程序。你可以想象它就是一个“隐形”的浏览器,只不过它没有图形界面,但能做我们用普通浏览器所能做…

基于Node+HeadlessBrowser的浏览器自动化方案

什么是无头浏览器(Headless Browser)?

无头浏览器,就像是一个没有用户界面的浏览器程序。你可以想象它就是一个“隐形”的浏览器,只不过它没有图形界面,但能做我们用普通浏览器所能做的大部分事情,比如打开网页、执行 JavaScript、进行页面互动等。无头浏览器最常用的场景就是在自动化测试、网页抓取、服务器上执行任务等不需要用户界面的场合。

使用无头浏览器,你无需打开真正的浏览器窗口就可以让程序去浏览网页、录制操作、生成截图等等,特别适合那些需要在没有人手动操作的情况下处理网页内容的任务。

特性PlaywrightPuppeteerSeleniumPhantomJS
支持浏览器Chromium, Firefox, WebKitChromium所有主流浏览器已内置 WebKit
平台支持Windows, Mac, LinuxWindows, Mac, LinuxWindows, Mac, LinuxWindows, Mac, Linux
多浏览器支持
API 现代性现代且易用现代且易用较复杂,学习曲线陡峭较简单
开发活跃度活跃且增长快活跃非常活跃已停止维护
适用场景自动化测试、爬虫、跨浏览器兼容性测试浏览器自动化测试和爬虫复杂测试流程静态网页抓取
启动速度较慢
资源占用
文档和社区支持良好优秀广泛限制, 文档停滞
  • Playwright:适合需要多浏览器支持的项目,API 现代且跨平台,对新功能的支持很快。
  • Puppeteer:专注于 Chromium,适合简单的自动化测试和爬虫任务。
  • Selenium:对于复杂的跨浏览器测试任务是很好的选择,但需要较多的配置和学习。
  • PhantomJS:虽然轻量且快速,但由于停止维护,而其使用逐渐减少,不建议用于新项目。

一、依赖安装

以下用Playwright为例,实现几个模拟浏览器操作的案例

// 安装无头浏览器依赖
npm i playwright --save
// 安装浏览器内核
npx playwright install

二、具体自动化操作

ScreenHotUtils.js提供了三个案例方法

  • 对目标网页进行截取
  • 获取目标页面的大标题
  • 获取目标页面Window对象的任意属性
// 注入chromium内核
const { chromium } = require('playwright');/*** 异步暂停方法* @param {number} delay - 时长(以毫秒为单位)* @returns {Promise<void>}*/
const sleep = delay => new Promise(resolve => setTimeout(resolve, delay));/*** 网页截屏方法* @param {string} webPageUrl - 目标网页地址* @param {number} loadDelay - 网页加载延时(以毫秒为单位)* @param {number} width - 浏览器宽度* @param {number} height - 浏览器高度* @param {boolean} fullPage - 是否进行全屏长截图* @returns {Promise<Buffer>} - 截图图像的Buffer*/
const captureWebPageScreenshot = async (webPageUrl,loadDelay = 1000,width = 1980,height = 1024,fullPage = false
) => {// 创建浏览器对象const browser = await chromium.launch();// 创建一个新的页面const page = await browser.newPage({viewport: {width,height,},});// 跳转到目标页await page.goto(webPageUrl);// 等待页面加载完成await page.waitForLoadState('load');// 页面加载延时await sleep(loadDelay);// 截图,并获取一个Bufferconst screenFileBuffer = await page.screenshot({ fullPage });// 关闭浏览器await browser.close();return screenFileBuffer;
};/*** 获取网页标题* @param {string} webPageUrl - 目标网页地址* @param {number} loadDelay - 网页加载延时(以毫秒为单位)* @returns {Promise<string>} - 网页标题*/
const getWebPageTitle = async (webPageUrl, loadDelay = 1000) => {// 创建浏览器对象const browser = await chromium.launch();const page = await browser.newPage();await page.goto(webPageUrl);await page.waitForLoadState('load');await sleep(loadDelay);// 获取页面标题const title = await page.title();await browser.close();return title;
};/*** 获取Window属性* @param {string} webPageUrl - 目标网页地址* @param {string[]} propertyNames - 要获取的属性名称列表* @returns {Promise<string>} - 获取的属性值*/
const getWindowProperty = async (webPageUrl, propertyNames) => {const browser = await chromium.launch();const page = await browser.newPage();await page.goto(webPageUrl);await page.waitForLoadState('load');// 使用 evaluate 在页面上下文中运行脚本const propertyValue = await page.evaluate(propertyNames => {const result = propertyNames.reduce((pre, prop) => {pre = pre[prop];return pre;}, window);return result;}, propertyNames);await browser.close();return propertyValue;
};module.exports = {getWebPageTitle,getWindowProperty,captureWebPageScreenshot,
};

三、执行测试

const {getWebPageTitle,captureWebPageScreenshot,getWindowProperty,
} = require('./ScreenHotUtils');
const fs = require('fs');
const path = require('path');(async () => {const webPageUrl = `http://www.baidu.com`;//   执行截图动作const fileBuffer = await captureWebPageScreenshot(webPageUrl);// 写入本地 | 上传OSS | 其他fs.writeFileSync(path.resolve(__dirname, './screenShot.png'), fileBuffer);//   获取页面标题const pageTitle = await getWebPageTitle(webPageUrl);console.log('PageTitle', pageTitle); // 百度一下 你就知道// 获取页面cookieconst cookie = await getWindowProperty(webPageUrl, ['document', 'cookie']);console.log('Cookie:', cookie); // cookie......
})();

效果:
在这里插入图片描述
就这样,我们可以轻松获得一个页面截图,通过代码就能在不打开浏览器的情况下获取到网页的图像,来实现一些自动化巡检&截图工具。


文章转载自:

http://8lW6c5rE.rgpbk.cn
http://c9s3Ihgt.rgpbk.cn
http://QlZtWVoQ.rgpbk.cn
http://yLSpqdPa.rgpbk.cn
http://PRhxX9wH.rgpbk.cn
http://09awZNYx.rgpbk.cn
http://hkprImpz.rgpbk.cn
http://2dW2BTxC.rgpbk.cn
http://Dt8J6DPN.rgpbk.cn
http://TL19FgUO.rgpbk.cn
http://haKoufgy.rgpbk.cn
http://VxFILoyh.rgpbk.cn
http://FBpc9u2x.rgpbk.cn
http://dEDYKWK3.rgpbk.cn
http://HeV34quk.rgpbk.cn
http://bJzLym2t.rgpbk.cn
http://eZyehYSx.rgpbk.cn
http://Esj9XWhe.rgpbk.cn
http://nBocDE8C.rgpbk.cn
http://uGRxRpEH.rgpbk.cn
http://YYP1Xjq9.rgpbk.cn
http://vNYtHRv8.rgpbk.cn
http://E66vu9bL.rgpbk.cn
http://8SKIvOyH.rgpbk.cn
http://0aRiPj0w.rgpbk.cn
http://43v32i5z.rgpbk.cn
http://cV3HaDbY.rgpbk.cn
http://zo6FL5yS.rgpbk.cn
http://A1W2HTy0.rgpbk.cn
http://5gobnGRh.rgpbk.cn
http://www.dtcms.com/wzjs/642936.html

相关文章:

  • 优化网站公司价格是多少钱wordpress论坛模版
  • 网页设计动画网站o2o商城源码
  • 留言板网站模板郑州小程序开发公司
  • 成都公司建站模板新区快速seo排名
  • 深圳定制网站制作咨询电话中国建设工程招投标网站
  • 农村学校资源网站建设与研究园区网站到底怎么建设
  • 聊城网站百度推广电商网站成功的营销策略
  • 网站模板 古典长春网站设计网站建设网站制作880元
  • 游戏网站外链建设域名备案必须要有服务器吗
  • 网站开发技术入股协议东营seo网站推广费用
  • 网站设计工程师是it行业吗不懂代码如何做网站
  • 网站开发实用技术答案php网站转移
  • 南阳网(网站).桂林企业网站建设
  • 网站开发开发需求文档优化网站排名费用
  • 深圳模板网站建设案例做网站流量
  • 北屯网站建设微商客源人脉app下载
  • 莆田外贸网站建设有哪些机电设备网站模板
  • 站长统计芭乐官方网站下载wordpress 中文名注册
  • 网站建设 找vx cp5173前端培训机构推荐
  • 昆山做网站找哪家好wordpress装修套餐网站源码
  • 公司企业网站建设目的东莞常平建设局网站
  • 东源县住房和城乡建设部网站盘锦网站变建设
  • 网站建设主要推广方式wordpress信息收集表单制作
  • 邯郸网站建设服务dw中网站建设的基本流程
  • 做网站背景图片要多大图片转链接生成器网站
  • 抖音做我女朋友好不好网站企业网站建设方案包含
  • 国外网站如何备案微信相册怎么制作
  • 有自己网站好处网站关键词优化公司哪家好
  • 重庆做网站外包公司品牌网站建设 蝌蚪6小
  • 个人网站制作模板地方网站 域名选择