PhantomJS & SlimerJS

PhantomJS

解決辦法

snipaste_20170718_092652.png

** 將網(wǎng)頁變成圖片,生成pdf浪汪,超級好用 **
抓取圖片,生成pdf

SlimerJS

下載

下載slimerjs

安裝slimerjs

二者區(qū)別
PhantomJS的代碼基本可以在SlimerJS上運行,用了PhantomJS之后還選擇SlimerJS的主要原因是PhantomJS的onResourceReceived方法不能返回body翘贮,slimerJS要正確返回body有個很重要的配置:** page.captureContent = [/.*/]; **幻赚,要認真看document啊禀忆,不然整天的時間都會耗費在坑里。

從stack overflow上找到解決方法

接觸到phantomjs和slimerjs的主要原因是因為框架從express 3.x升級到express 4.x 時生成report出現(xiàn)了詭異的error落恼,因此追蹤瀏覽器行為箩退。在cmd啟動slimerjs執(zhí)行phtest.js

slimerjs phtest.js

以下是追蹤request和response的代碼phtest.js

var page = require('webpage').create();
var fs = require('fs');
var settings = {
   operation: 'POST',
   headers: {
           'app_key_pjs': '***'
   }
};
var requestBuf = 'Request : ';
var receiveBuf = 'Receive : ';
var temp1 = {};
var temp2 = {};
var pjs_login_url = "https://admin-dev.tmcas.trendmicro.com/pjs_login/aad0ae50-4b4c-11e7-a72a-f9fb4c6dbe68";
var generate_report_url = "https://admin-dev.tmcas.trendmicro.com/#!/logs/report/8fb4b3b0-6ac7-11e7-b38f-6dbe26a4fd8f";
page.captureContent = [/.*/];
page.onResourceRequested = function(request) {
        temp1 = {
        'id': request.id,
        'url': request.url,
        'method':request.method,
        'time': request.time,
        'postData': request.postData
        };
        console.log('Request ' + JSON.stringify(temp1, undefined, 4));

//  requestBuf += JSON.stringify(request, undefined, 4);
};
page.onResourceReceived = function(response) {
    //console.log('Receive ' + JSON.stringify(response, undefined, 4));
    temp2 = {
        'id': response.id,
        'url': response.url,
        'time': response.time,
        'stage':response.stage,
        'status':response.status,
        'statusText': response.statusText,
        'body': response.body
        };
    console.log('Receive ' + JSON.stringify(temp2, undefined, 4));
    //receiveBuf += response.id + ' : ' + response.url +'; body: ' +response.body + '\r\n';
};
phantom.cookieEnabled = true;
phantom.addCookie({
    'name': 'x-phantomjs-accept-language',
    'value': 'en',
    'domain':'10.0.11.253',
    'path':'/pjs_login'
});


page.open(pjs_login_url,'post','company_guid', {'app_key_pjs': '***'}, function(status){
    if(status !== 'success'){
        console.log('fail to pjs_login');
        phantom.exit();
    }else{
        console.log('success to pjs login');
        page.open(generate_report_url,function(status){
            if ( status !== 'success'){
                console.log('Fail to get logs');
                phantom.exit();
            }else{
                console.log('get logs success');
                var rendered = false;
                page.onConsoleMessage = function (msg) {
                    //fs.open('b5.json', 'w').write(receiveBuf);
                        // do something e.g. page.render
                        if (msg == "LOGS_LOADED" && !rendered) {
                            rendered = true;
                            console.log("Logs load status: " + msg + " Start to render page");
                            //Wait 1 second in case of DOM is not refresh after data received
                            setTimeout(function () {
                                phantom.exit();
                            }, 1000);
                        } else if (msg == "LOGS_LOADED_FAIL") {
                            rendered = true;
                            console.log("Fail to load logs data: " + msg);
                            phantom.exit();
                        } else {
                            console.log("Not logs load: " + msg);
                            phantom.exit();
                        }
                }           
            }
        });
    }
});

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市佳谦,隨后出現(xiàn)的幾起案子戴涝,更是在濱河造成了極大的恐慌,老刑警劉巖吠昭,帶你破解...
    沈念sama閱讀 218,858評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件喊括,死亡現(xiàn)場離奇詭異,居然都是意外死亡矢棚,警方通過查閱死者的電腦和手機郑什,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,372評論 3 395
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來蒲肋,“玉大人蘑拯,你說我怎么就攤上這事钝满。” “怎么了申窘?”我有些...
    開封第一講書人閱讀 165,282評論 0 356
  • 文/不壞的土叔 我叫張陵弯蚜,是天一觀的道長。 經(jīng)常有香客問我剃法,道長碎捺,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,842評論 1 295
  • 正文 為了忘掉前任贷洲,我火速辦了婚禮收厨,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘优构。我一直安慰自己诵叁,他們只是感情好,可當我...
    茶點故事閱讀 67,857評論 6 392
  • 文/花漫 我一把揭開白布钦椭。 她就那樣靜靜地躺著拧额,像睡著了一般。 火紅的嫁衣襯著肌膚如雪彪腔。 梳的紋絲不亂的頭發(fā)上侥锦,一...
    開封第一講書人閱讀 51,679評論 1 305
  • 那天,我揣著相機與錄音漫仆,去河邊找鬼捎拯。 笑死,一個胖子當著我的面吹牛盲厌,可吹牛的內(nèi)容都是我干的署照。 我是一名探鬼主播,決...
    沈念sama閱讀 40,406評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼吗浩,長吁一口氣:“原來是場噩夢啊……” “哼建芙!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起懂扼,我...
    開封第一講書人閱讀 39,311評論 0 276
  • 序言:老撾萬榮一對情侶失蹤禁荸,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后阀湿,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體赶熟,經(jīng)...
    沈念sama閱讀 45,767評論 1 315
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,945評論 3 336
  • 正文 我和宋清朗相戀三年陷嘴,在試婚紗的時候發(fā)現(xiàn)自己被綠了映砖。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,090評論 1 350
  • 序言:一個原本活蹦亂跳的男人離奇死亡灾挨,死狀恐怖邑退,靈堂內(nèi)的尸體忽然破棺而出竹宋,到底是詐尸還是另有隱情,我是刑警寧澤地技,帶...
    沈念sama閱讀 35,785評論 5 346
  • 正文 年R本政府宣布蜈七,位于F島的核電站,受9級特大地震影響莫矗,放射性物質(zhì)發(fā)生泄漏飒硅。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,420評論 3 331
  • 文/蒙蒙 一趣苏、第九天 我趴在偏房一處隱蔽的房頂上張望狡相。 院中可真熱鬧梯轻,春花似錦食磕、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,988評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間趁餐,已是汗流浹背亲怠。 一陣腳步聲響...
    開封第一講書人閱讀 33,101評論 1 271
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留京革,地道東北人。 一個月前我還...
    沈念sama閱讀 48,298評論 3 372
  • 正文 我出身青樓,卻偏偏與公主長得像区转,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子版扩,可洞房花燭夜當晚...
    茶點故事閱讀 45,033評論 2 355

推薦閱讀更多精彩內(nèi)容