首頁>資訊中心>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 極速建站平臺 構站網
        亚洲最大的成人网站| 亚洲av无码潮喷在线观看| 内射少妇36P亚洲区| 亚洲熟妇av一区二区三区| 亚洲精品tv久久久久| 国产精品亚洲а∨无码播放麻豆 | 亚洲精品国产国语| 亚洲国产人成在线观看| 亚洲免费闲人蜜桃| 亚洲精品第一国产综合野| 亚洲综合色区中文字幕| 亚洲www77777| 亚洲成AV人片在WWW| 国产亚洲一卡2卡3卡4卡新区 | 亚洲AV无码国产一区二区三区| 亚洲人成色4444在线观看| 亚洲日韩中文字幕一区| 亚洲爆乳大丰满无码专区| 亚洲a∨国产av综合av下载| 99亚洲乱人伦aⅴ精品| 亚洲av再在线观看| AV在线播放日韩亚洲欧| 亚洲午夜未满十八勿入网站2| 国产亚洲精品无码成人| 亚洲AV永久纯肉无码精品动漫| 亚洲精品线在线观看| 亚洲精品国产情侣av在线| 亚洲中文字幕在线无码一区二区| 亚洲人精品亚洲人成在线| 亚洲女女女同性video| 一级毛片直播亚洲| 伊人久久亚洲综合| 久久精品7亚洲午夜a| 亚洲大尺码专区影院| 涩涩色中文综合亚洲| 亚洲第一se情网站| 亚洲一区二区三区国产精品| 国产精品亚洲片在线观看不卡| 亚洲五月激情综合图片区| 亚洲国产av高清无码| 亚洲精品无码久久久久YW|