Headless Chrome bezieht sich auf die Ausführung von Google Chrome im Headless-Modus. Das Wesentliche ist, Google ohne Google zu betreiben! Es übersetzt alle Funktionen moderner Webplattformen, die von den Rendering-Engines Chromium und Blink bereitgestellt werden, in die Befehlszeile.
Wofür wird es verwendet?
Headless Browser ist ein großartiges Tool für automatisierte Tests und Server, die keine visuelle Benutzeroberfläche erfordern. Sie möchten beispielsweise einige Tests auf einer Webseite ausführen, eine PDF-Datei aus der Webseite erstellen oder einfach überprüfen, wie der Browser die URL übermittelt.
Warnung: Chrome 59 auf Mac und Linux kann im Headless-Modus ausgeführt werden. Windows-Unterstützung wird in Kürze bereitgestellt.
Download-Adresse
Vergleich mehrerer Versionen
Chromium ist nicht Chrome, aber der Inhalt von Chrome ist im Wesentlichen von Chromium abgeleitet. Dies ist eine Open-Source-Version, die stündlich aktualisiert wird
Canary ist eine Testversion, was bedeutet, dass Canary sehr empfindlich gegenüber giftigen Gasen ist. Wenn die Konzentration etwas höher ist, hört es auf zu zwitschern oder stirbt sogar ab und andere giftige Gase. Sie ist auch in Huang Bos Operation in „Das Geheimnis des Drachen“ zu sehen. Haha, ich gehe zu weit, das ist die Daily Build-Version.
Dev ist die Entwicklungsversion, wöchentliche Build-Version
Beta ist die Testversion, monatliche Build-Version
Stable ist eine stabile Version und wird normalerweise etwa einmal im Monat aktualisiert
Update-Häufigkeit Chromium > Chrome Beta >
Nur einer von Chrome Dev, Chrome Beta und Chrome Stable kann gleichzeitig angezeigt werden
Chromium, Chrome Canary und alle anderen beide können nebeneinander existieren
Der Windows-Plattform-Download darf nur ein Online-Installationsprogramm sein, fügen Sie Parameter in der URL der Download-Seite hinzustandalone=1
Fügen Sie ~/.bashrc
1 2 |
|
hinzu und öffnen Sie das Terminal erneut. Wir können die stabile Version von Chrome direkt öffnen chrome
, chrome-canary
Öffnen Sie die experimentelle Version von Chrome.
Beachten Sie die offiziellen Anweisungen. Der Headless-Modus erfordert Chrome-Version >= 59
Öffnen Sie die Baidu-Homepage von Chrome (mit Schnittstelle). Sie können sehen, wie sich der Browser öffnet Öffnen Sie die Baidu-Homepage (keine Schnittstelle), aber sie wird nicht in der Browseroberfläche geöffnet, aber es werden Symbole in der Taskleiste angezeigt
chrome
Schnittstellenlosen Modus verwenden. Starten Sie Chrome und konvertieren Sie die Seite in PDF. Sie können die Ausgabe von
chrome --headless
Starten Sie Chrome im schnittstellenlosen Modus. Machen Sie einen Screenshot. Sie können die Ausgabe von output.pdf
chrome --headless --print-to-pdf
Starten Sie Chrome in sehen Headless-Modus und öffnen Sie die interaktive Umgebungscreenshot.png
chrome --headless --screenshot --window-size=414,736
chrome --headless --repl
chrome --headless --remote-debugging-port=9222
chrome --headless --remote-debugging-port=9222
Sehen Sie sich die Befehlsbeschreibung an. Verschiedene verwandte Vorgänge können hier ausgeführt werdenchrome-remote-interface
$ chrome-remote-interface npm install chrome-remote-interface -g
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 |
|
chrome-remote-interface new
chrome-remote-interface inspect
Headless Chrome programmgesteuert ausführen
kann über die Systemaufrufmethode ausgeführt werden, die die obige Befehlszeilenausführungsmethode direkt aufruft. Dieser Ansatz erfordert einige Arbeit in einem plattformübergreifenden Kontext. >>> Runtime.evaluate({expression:'location.href'})
Google出品的Lighthouse 这个网页质量检查工具,有一个组件专门做这事,考虑了各种平台的兼容性问题,源码参考lighthouse-chromelauncher,这个组件现在已经单独独立出来,作为一个单独的NPM
组件chrome-launcher
,可以直接使用这个在Node
平台下调用,其他平台的也可以此为参考。
const chromeLauncher = require('chrome-launcher');//启用无界面模式并开启远程调试,不同引用版本和方式,调用方式可能有些区别//chromeLauncher.run({chromeLauncher.launch({// port: 9222,chromeFlags: ['--headless']}).then((chrome) => {// 拿到一个调试客户端实例console.log(chrome)chrome.kill();});
实现了ChromeDevTools
协议的工具库有很多,chrome-remote-interface
是NodeJS的实现。
Chrome调试Server开启的是WebSocket交互的相关实现,要用编程的方式实现还需要封装一些WebSocket命令发送、结果接收等这一系列操作,这些chrome-remote-interface
已经帮我们做了,更多实例可以参考chrome-remote-interface的wiki。
const chromeLauncher = require('chrome-launcher');const chromeRemoteInterface = require('chrome-remote-interface')//启用无界面模式并开启远程调试,不同引用版本和方式,调用方式可能有些区别//chromeLauncher.run({chromeLauncher.launch({port: 9222,chromeFlags: ['--headless']}).then((launcher) => {chromeRemoteInterface.Version({host:'localhost',port:9222}).then(versionInfo => {console.log(versionInfo)});chromeRemoteInterface({host:'localhost',port:9222}).then((chrome) => {//这里调用ChromeDevToolsProtocol定义的接口const {Network,Page} = chrome;Network.requestWillBeSent((params) => {let {request} = params;let {url} = request;console.log(url)});Promise.all([Network.enable(),Page.enable() ]).then(() => {Page.navigate({url:'https://www.baidu.com'})});setTimeout(() => {launcher.kill()},5000);})});
Das obige ist der detaillierte Inhalt vonEine beispielhafte Einführung in die Headless Chrome-Entwicklungstool-Bibliothek. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!