最近做項(xiàng)目刹淌,需要實(shí)現(xiàn)網(wǎng)頁抓屏饶氏。摸索后讥耗,決定采用phantomjs 實(shí)現(xiàn)有勾。
phantomjs 的功能很強(qiáng)大,做爬蟲應(yīng)用古程,抓取網(wǎng)頁數(shù)據(jù)蔼卡、網(wǎng)頁截屏、頁面訪問自動化等挣磨。
主要是 針對 抓屏的 demo實(shí)現(xiàn).
php 代碼:
<?php
/**
* Created by PhpStorm.
* User: Administrator
* Date: 2017/11/9 0009
* Time: 下午 4:41
*/
$dir = '';
$cmd = "{$dir}phantomjs --output-encoding=utf-8 ";
$js = $dir . "imagebin.js ";
$url = " http://baidu.com ";
$img_path = 'test.jpg';
$parms = " 795*1110px ";
$ssl = "{$cmd}{$js}{$url}{$img_path}{$parms}";
exec($ssl, $log, $status);
JS 代碼:
var page = require('webpage').create(),
system = require('system'),
address, output, size;
//system 獲得系統(tǒng)操作對象雇逞,包括命令行參數(shù)、phantomjs系統(tǒng)設(shè)置等信息
// page獲取操作dom或web網(wǎng)頁的對象茁裙,通過它可以打開網(wǎng)頁塘砸、接收網(wǎng)頁內(nèi)容、request
if (system.args.length < 3 || system.args.length > 5) {
console.log('Usage: rasterize.js URL filename [paperwidth*paperheight|paperformat] [zoom]');
console.log(' paper (pdf output) examples: "5in*7.5in", "10cm*20cm", "A4", "Letter"');
console.log(' image (png/jpg output) examples: "1920px" entire page, window width 1920px');
console.log(' "800px*600px" window, clipped to 800x600');
phantom.exit(1);
} else {
address = system.args[1];
output = system.args[2];
page.viewportSize = {width: 600, height: 600};
if (system.args.length > 3 && system.args[2].substr(-4) === ".pdf") {
size = system.args[3].split('*');
page.paperSize = size.length === 2 ? {width: size[0], height: size[1], margin: '0px'}
: {format: system.args[3], orientation: 'portrait', margin: '1cm'};
} else if (system.args.length > 3 && system.args[3].substr(-2) === "px") {
size = system.args[3].split('*');
// console.log(size);
// phantom.exit(1);
if (size.length === 2) {
pageWidth = parseInt(size[0], 10);
pageHeight = parseInt(size[1], 10);
page.viewportSize = {width: pageWidth, height: pageHeight};
page.clipRect = {top: 10, left: 10, width: pageWidth, height: pageHeight};
} else {
console.log("size:", system.args[3]);
pageWidth = parseInt(system.args[3], 10);
pageHeight = parseInt(pageWidth * 3 / 4, 10); // it's as good an assumption as any
console.log ("pageHeight:", pageHeight);
page.viewportSize = {width: pageWidth, height: pageHeight};
}
}
if (system.args.length > 4) {
page.zoomFactor = system.args[4];
}
page.open(address , function (status) {
if (status !== 'success') {
console.log('Unable to load the address!');
phantom.exit(1);
} else {
window.setTimeout(function () {
page.render(output);
phantom.exit();
}, 200);
}
});
}
附 下載地址: