首頁>資訊中心>PHP網頁截取快照:PHP截取網站網頁保存為一張圖片實現。

        PHP網頁截取快照:PHP截取網站網頁保存為一張圖片實現。


        更新時間:2021/12/16 文章來源:新格通達 瀏覽:801 編輯:創始人 搜索看看

        phantomjs截取網頁截圖
        場景
        有一個視頻播放地址,需要對該網頁進行截圖
        解決思路:
        1.將視頻下載到本地,使用ffmpeg進行處理
        2.使用phantomjs,phantomjs內置了webkit瀏覽器引擎,phantomjs可以模擬瀏覽器打開視頻地址,然后進行整個網頁的截圖。
        WebKit 是一個開源的瀏覽器引擎,與之相對應的引擎有Gecko(Mozilla Firefox 等使用)和Trident(也稱MSHTML,IE 使用)
        選擇
        第一個方案,ffmpeg只能處理本地視頻或者處理RTCP直播流,同時要求的視頻直播地址中有部分是直播流,有部分是組件渲染,所以該方案不可行。
        因此選擇第二個方案。
        phantomjs進行網頁截圖,這里以window平臺為例
        1.首先,去phantomjs官網下載頁面下載phantomjs程序,支持window、mac os、linux、freebsd平臺。
        2.將下載下來的phantomjs添加系統環境變量里
        3.編寫js文件capture.js
        use strict;  //嚴格模式
        var page = require(&webpage&).create();
        var system = require(&system&);
        page.viewportSize = {
        width : 1024,
        height : 720
        };
        if (system.args.length < 3) {
        console.log(¶m must greater 2&);
        phantom.exit();
        } else{
        var url = system.args[1];  //遠程視頻地址
        var saveFile = system.args[2];  //保存截圖的文件路徑
        page.open(url, function(status) {
        if (status == &success&){
        // 通過在JS獲取頁面的渲染高度
        var rect = page.evaluate(function () {
        return document.getElementsByTagName(&html&)[0].getBoundingClientRect();
        });
        // 按照實際頁面的高度,設定渲染的寬高
        page.clipRect = {
        top:    rect.top,
        left:   rect.left,
        width:  rect.width,
        height: rect.height
        };
        setTimeout(function() {
        var result = page.render(saveFile);
        page.close();
        console.log(result);
        phantom.exit();
        }, 1000);  //延遲截圖時間
        }
        })
        }
        4.在php中進行調用
        $url = &http://xxx&;
        $savePath = &c:\test.png&;
        $jsPath = &c:\phantomjs.js&;
        $command = phantomjs {$jsPath}  {$url}  {$savePath};
        $result = @exec($command );
        這樣就對網頁進行截圖,保存截圖在指定路徑中。
        另外:有大神在github上提交了個操作phantomjs的php類庫,可以參考使用:
        https://github.com/jonnnnyw/php-phantomjs
        http://jonnnnyw.github.io/php-phantomjs/4.0/2-installation/
        ————————————————
        版權聲明:本文為CSDN博主「陪代碼一起浪跡天涯」的原創文章,遵循CC 4.0 BY-SA版權協議,轉載請附上原文出處鏈接及本聲明。
        原文鏈接:https://blog.csdn.net/seoyundu/article/details/101782923




        版權所有 新格通達 www.goz.cn 極速建站平臺 構站網
        亚洲人成电影亚洲人成9999网| 亚洲永久在线观看| 亚洲中文字幕乱码一区| 亚洲国产精品成人精品小说 | 亚洲成a人无码亚洲成www牛牛| 亚洲av极品无码专区在线观看| 亚洲成年人免费网站| 亚洲欧洲精品在线| 亚洲人成网站18禁止久久影院| 亚洲国产午夜精品理论片| 亚洲人成片在线观看| 亚洲一级视频在线观看| 亚洲人成图片网站| 亚洲人成人网站18禁| 欧美亚洲国产SUV| 亚洲高清最新av网站| 久久久久亚洲AV无码专区桃色| 国产午夜亚洲精品理论片不卡| 亚洲中文字幕无码永久在线| 精品亚洲永久免费精品| 亚洲av激情无码专区在线播放 | 久久亚洲私人国产精品vA| 亚洲激情中文字幕| 亚洲精品偷拍无码不卡av| 亚洲不卡视频在线观看| 亚洲色精品三区二区一区| 亚洲AV无码一区二区三区久久精品| 丰满亚洲大尺度无码无码专线| 无码欧精品亚洲日韩一区夜夜嗨| 亚洲精品视频在线看| 亚洲真人无码永久在线| 久久精品国产精品亚洲色婷婷 | 亚洲美女在线国产| 亚洲精品无码成人片久久| 久久久久亚洲精品美女| 亚洲人成网站在线观看播放青青| 亚洲国产欧美国产综合一区| 亚洲国产成人久久精品99| 亚洲乱亚洲乱妇无码麻豆| 亚洲精选在线观看| 亚洲一级毛片免费在线观看|