亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

使用Phantomjs和Node完成網頁的截屏快照的方法

2019-11-19 11:10:48
字體:
來源:轉載
供稿:網友

由于甲方爸爸的需要,最近使用phantomjs和Node寫了一個對網頁內容截屏的功能,為了避免忘記,現在將代碼內容及配置流程大概描述一下.

1.首先Node是必須安裝的,而且網上安裝教程一大堆,在此不再贅述,Nodejs官網鏈接

2.然后,第二個主人公是phantomjs,官網下載地址,選擇對應的系統下載對應的安裝包

3.將phantomjs配置為系統變量,下面是Windows配置為環境變量:

配置完成之后,在cmd命令行中輸入 phantomjs -v 檢驗是否配置成功,配置成功之后,如下圖所示:

4.擼代碼,通過查閱phantomjs入門代碼之后,了解到使用phantomjs可以預覽一個網頁生成圖片,PDF,base64格式等等,而我們的項目需要的并不是一個完整的網頁,而是網頁中的一部分內容,所以在此基礎之上要改造部門內容,現在講解一下代碼:

4.1)首先是express的一些設置,由于需要執行phantomjs的命令,所以需要引入child_process模塊,具體代碼如下:

var process = require('child_process');//執行命令行所需var express = require('express');//expressvar bodyParser = require('body-parser');var fs = require("fs");//文件操作var app = express(); app.use('/pages',express.static('pdfs'));//設置靜態資源目錄app.use(bodyParser.json({limit:'50mb'}));//請求內容大小限制app.use(bodyParser.urlencoded({limit:'50mb',extended:false}));  //設置允許跨域訪問var allowCrossDomain = function(req, res, next) {  res.header('Access-Control-Allow-Origin', '*');  res.header('Access-Control-Allow-Methods', 'GET,PUT,POST,DELETE');  res.header('Access-Control-Allow-Headers', 'Content-Type');  res.header('Access-Control-Allow-Credentials','true');  next();}; app.use(allowCrossDomain);

4.2)然后就是生成頁面的base64接口的方法,如下:

app.get('/getBase64',function(req,res){	var url=req.query.url;//讀取請求中的url參數,然后訪問這個url  url=url.replace(/&/g,'%26');//將請求中的&轉換 	var resp={	  "status":'200'	}	res.writeHead(200,{'Content-Type':'text/html;charset=utf-8'});//設置響應頭	if(url==''){    resp.msg='url參數不能為空';    res.end(JSON.stringify(resp));  	}	else{    //phantomjs執行的命令行 index.js在后文中給出		var strShell='phantomjs --disk-cache=true --disk-cache-path=. index.js '+url;    process.exec(strShell,{    	maxBuffer:5000*1024,    },function(error,stdout,strerr){    	if(error!==null){        console.log(error);    		resp.msg='轉換失敗,稍后重試';    		res.end(JSON.stringify(resp));    	}else{        //執行成功則返回base64的數據    		resp.data=stdout;    		res.end(JSON.stringify(resp));    	}    })	} })

4.3)phantomjs執行的腳本,即index.js,如下:

var page = require('webpage').create();//獲取webpagevar system = require('system'),  address; if (system.args.length === 1) {//執行的命令應該包括請求的URL,否則退出phantom  console.log('Usage: URL error');  phantom.exit();}address = system.args[1];//請求的地址address = address.replace(/%26/g, '&');//phantom不能識別%26,所以轉為&page.viewportSize = {//設置viewport  width: 1920,  height: 1080,}page.open(address, function(status) {//打開頁面  setTimeout(function() {//2s之后獲取base64結果,如果直接生成有可能頁面還沒有加載完成    if (status == 'success') {      var base64 = page.renderBase64('PNG');      console.log(base64);//將base64結果輸出之后,在上邊的getBase64接口中獲取      phantom.exit();    }  }, 2000);})

4.4)獲取頁面中部分內容的截圖,可以將需要截圖的DOM字符串,發送至后臺,然后新建一個空的頁面,使用phantom訪問該空白頁面,并將DOM字符串添加到預覽的頁面,然后生成截圖,具體代碼如下:

app.post('/getPartPage', function(req, res) {  var xmlObj = req.body.xmlObj;//獲取DOM字符串  const reqUrl = 'http:example.com/tmp.html';//要訪問的空頁面  var response = {    "status": '200',  };  if (xmlObj == undefined || xmlObj == '' || xmlObj == null) {    response.msg = 'DOM字符串內容未輸入';    res.end(JSON.stringify(response));  }else {    fs.writeFile('tmp.txt', xmlObj, function(err) { //由于dom字符串內容過多,所以寫入txt文本      if (err) {        response.msg = '生成頁面失敗,請稍后重試';        return res.end(JSON.stringify(response));      }       var strShell = 'phantomjs pages/index.js ' + reqUrl;//phantomjs執行的命令      process.exec(strShell, {        maxBuffer: 5000 * 1024,      }, function(error, stdout, strerr) {        if (error !== null) {          response.msg = '腳本執行錯誤,請稍后重試';          res.end(JSON.stringify(response));        } else {          response.data = stdout.replace("/r/n", "");          res.end(JSON.stringify(response));//返回結果        }       })     })   } }) var server = app.listen(8808,function(){ //接口監聽,訪問的端口	var host = server.address().address	var port = server.address().port  console.log('http://%s:%s',host,port);})

4.5)pages下的index.js內容如下所示:

var page = require('webpage').create();//獲取webpagevar fs = require('fs');var system = require('system'),  address,filename; if (system.args.length === 1) {  console.log('Usage: URL error');  phantom.exit();}address = system.args[1];//請求的路徑address = address.replace(/%26/g, '&');filename = (new Data()).getTime();page.viewportSize = {  width: 750,}page.paperSize = { //生成A4大小的PDF文件  format: 'A4',  orientation: 'portrait',  margin: '0.8cm'}page.open(address, function(status) {  var info = fs.read('tmp.txt');//讀取DOM字符串  var result = page.evaluate(function(info) {    try {      document.querySelector('#dom').innerHTML = info;//將dom字符串拼接    } catch (e) {      console.log(e);    }     return document.querySelector('#dom').innerHTML;//返回頁面  }, info);  setTimeout(function() {    page.paperSize = {      format: 'A4',      orientation: 'portrait',      margin: '0.8cm'    };    page.viewportSize = {      width: 750,    };    //生成PDF文件     page.render('pages/' + filename + '.pdf', { format: 'pdf', quality: '100' });    console.log('http://example.com/pages/' + filename + '.pdf');//返回PDF文件的訪問路徑    phantom.exit();  }, 500);})

OK,以上就是全部接口的內容,全部的代碼可以訪問https://github.com/kim095/node-phantom進行下載.希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
成人淫片在线看| 精品无人区太爽高潮在线播放| 青青草原成人在线视频| 久久久成人av| 国产精品久久久| 国产精品久久久久久久久粉嫩av| www高清在线视频日韩欧美| 亚洲精品国产精品乱码不99按摩| 国产精品午夜国产小视频| 亚洲国产精品久久91精品| 久久久久久久久久av| 精品国产一区二区三区久久久狼| 亚洲精品自拍偷拍| 欧美一区第一页| 尤物yw午夜国产精品视频明星| 欧美精品免费在线观看| 久久久精品一区| 欧美日韩国产区| 国产精品欧美激情| 91夜夜揉人人捏人人添红杏| 亚洲网站视频福利| 亚洲色图激情小说| 欧美性猛交xxxx乱大交蜜桃| 38少妇精品导航| 久久久亚洲欧洲日产国码aⅴ| 国产欧美精品日韩精品| 亚洲午夜久久久影院| 亚洲精品国产免费| 亚洲乱码一区av黑人高潮| 国产精品久久久久久久av大片| 亚洲午夜激情免费视频| 国产精品嫩草影院一区二区| 欧美性在线视频| 久久精品国产亚洲一区二区| 成人观看高清在线观看免费| 日本一区二区三区四区视频| 91po在线观看91精品国产性色| 国产精品永久免费视频| 国产欧美日韩精品专区| 久久免费视频这里只有精品| www国产亚洲精品久久网站| 91在线|亚洲| 国产精品一区久久| 国产免费一区二区三区在线能观看| 国产精品激情av电影在线观看| 久久手机免费视频| 亚洲一区二区三区xxx视频| 国产精品视频大全| 奇米四色中文综合久久| 疯狂做受xxxx高潮欧美日本| 国产亚洲欧洲高清一区| 色综合色综合久久综合频道88| 亚洲欧洲国产伦综合| 欧美在线激情网| 亚洲性夜色噜噜噜7777| 欧美成人小视频| 亚洲性视频网址| 中文字幕一区二区精品| 欧美日韩激情小视频| 九九视频这里只有精品| 成人在线精品视频| 亚洲激情在线视频| 国产精品自产拍高潮在线观看| 日韩精品免费在线视频观看| 国产精品一区二区女厕厕| 欧美激情精品久久久久久蜜臀| 欧美成人中文字幕在线| 久久99国产综合精品女同| 久久69精品久久久久久国产越南| 色www亚洲国产张柏芝| 国产成人拍精品视频午夜网站| 欧洲成人免费aa| 欧美洲成人男女午夜视频| 国产v综合v亚洲欧美久久| 国产精品一二区| 久久韩剧网电视剧| 日韩欧美在线观看| 国产一区二区三区在线播放免费观看| 日韩电影在线观看永久视频免费网站| 欧美激情三级免费| 日韩精品一区二区视频| 久久综合免费视频| 中文字幕欧美精品日韩中文字幕| 欧美老女人性视频| 夜夜嗨av色综合久久久综合网| 精品高清一区二区三区| 欧美激情2020午夜免费观看| 日韩的一区二区| 亚洲第一精品夜夜躁人人躁| 欧美精品videos另类日本| 久久久视频精品| 97婷婷大伊香蕉精品视频| 亚洲欧美色图片| 国产精品欧美亚洲777777| 国产日产久久高清欧美一区| 欧美在线视频免费观看| 亚洲欧美日韩久久久久久| 国产精品v片在线观看不卡| 久久精品99久久久香蕉| 欧美精品在线视频观看| 日韩av不卡在线| 欧美高清在线播放| 国产精品欧美激情| 国产成人高清激情视频在线观看| 91产国在线观看动作片喷水| 亚洲精品午夜精品| 欧美日韩成人在线播放| 日本国产高清不卡| 91在线网站视频| 欧美性精品220| 伊人久久男人天堂| 欧美亚洲激情视频| 国产欧美中文字幕| 日韩欧美有码在线| 日韩av不卡在线| 亚洲最新视频在线| 亚洲欧美一区二区三区情侣bbw| 伊人久久免费视频| 欧洲亚洲妇女av| 欧美乱人伦中文字幕在线| 欧美电影免费观看高清完整| 欧美亚洲视频一区二区| 欧美电影免费观看高清| 日韩精品在线免费播放| 欧美猛少妇色xxxxx| 亚洲欧美日韩视频一区| 欧美一区二区三区精品电影| 国产精品白嫩初高中害羞小美女| 欧美黑人一级爽快片淫片高清| 亚洲成人精品久久| 日本欧美精品在线| 精品高清美女精品国产区| 91免费在线视频网站| 中文字幕日韩电影| 久久人人爽人人爽人人片亚洲| 4388成人网| 最近2019免费中文字幕视频三| 91av在线免费观看| 日韩中文在线中文网三级| 欧美最近摘花xxxx摘花| 欧美亚洲国产成人精品| 精品久久久香蕉免费精品视频| 亚洲精品自拍视频| 久久久久久久999精品视频| 国产盗摄xxxx视频xxx69| 欧美激情一级欧美精品| 68精品久久久久久欧美| 中文字幕九色91在线| 日韩欧美国产一区二区| 国产日产欧美精品| 国产美女精品视频| 国内外成人免费激情在线视频网站| 日韩欧美在线网址| 亚洲性视频网站| 国产精品麻豆va在线播放| 欧美成aaa人片免费看| 国产在线98福利播放视频| 国模私拍视频一区| 欧美成人高清视频| 91高清视频免费观看| 亚洲欧美日韩天堂| 2019中文字幕在线免费观看| 孩xxxx性bbbb欧美| 欧美激情性做爰免费视频|