在ws://127.0.0.1:9222 / devtools / browser /上监听的DevTools
文档中的@AndreaCardaci在 单独的上下文 中
加载URL 时提到 在无头模式下 使用 Google
Chrome时 :
普通的示例代码每次都在单独的上下文中的新的一次性选项卡中运行(认为它是隐身配置文件)。
为了从Chrome 62开始获取浏览器版本,浏览器目标URL是在运行时生成的,可以通过 /json/version
端点获取,/devtools/browser
如果没有的话,可以回退到目标URL 。
以下是相关代码:
const CDP = require('chrome-remote-interface');async function doInNewContext(action) { // fetch the browser version (since Chrome 62 the browser target URL is // generated at runtime and can be obtained via the '/json/version' // endpoint, fallback to '/devtools/browser' if not present) const {webSocketDebuggerUrl} = await CDP.Version(); // connect to the DevTools special target const browser = await CDP({ target: webSocketDebuggerUrl || 'ws://localhost:9222/devtools/browser' }); // create a new context const {Target} = browser; const {browserContextId} = await Target.createBrowserContext(); const {targetId} = await Target.createTarget({ url: 'about:blank', browserContextId }); // connct to the new context const client = await CDP({target: targetId}); // perform user actions on it try { await action(client); } finally { // cleanup await Target.closeTarget({targetId}); await browser.close(); }}// this basically is the usual exampleasync function example(client) { // extract domains const {Network, Page} = client; // setup handlers Network.requestWillBeSent((params) => { console.log(params.request.url); }); // enable events then start! await Promise.all([Network.enable(), Page.enable()]); await Page.navigate({url: 'https://github.com'}); await Page.loadEventFired();}doInNewContext(example);此外,按照获取浏览器目标URL(ws:// localhost:9222 / devtools / browser /
…)的方式,可以
http://127.0.0.1:9222/json/version在
webSocketDebuggerUrl字段中通过端点访问。所以,或者,如果您正在使用的选项启动铬
--remote-debugging-port=0,无论 端口 和 端点 被写入 DevToolsAcivePort 在浏览器配置文件夹文件。
结论
该错误不会影响您
@Test,您可以暂时忽略该错误。



