成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

一步一步搭建前端監(jiān)控系統(tǒng):如何將網(wǎng)頁截圖上報?

Martin91 / 612人閱讀

摘要:目前已經(jīng)在運行的線上前端監(jiān)控系統(tǒng)代碼和講解都放在這篇文章里監(jiān)控系統(tǒng)介紹及代碼用戶對前端程序員來說,就是一個黑匣子。

摘要: 通過錄屏或者截圖,快速復(fù)現(xiàn)BUG場景。

作者:一步一個腳印一個坑

原文:搭建前端監(jiān)控系統(tǒng)(備選)Js截圖上報篇

Fundebug經(jīng)授權(quán)轉(zhuǎn)載,版權(quán)歸原作者所有。

PS:本文關(guān)于Fundebug錄屏功能的內(nèi)容有些不準確的地方,比如錄屏并非通過截圖實現(xiàn)的,錄屏插件的BUG也已經(jīng)修復(fù)了,錄屏并非只支持Chrome,錄屏數(shù)據(jù)并不大,錄屏性能也優(yōu)化了很多。

背景:市面上的監(jiān)控系統(tǒng)有很多,大多收費,對于小型前端項目來說,必然是痛點。另一點主要原因是,功能雖然通用,卻未必能夠滿足我們自己的需求,所以我們自給自足也許是個不錯的辦法。

這是搭建前端監(jiān)控系統(tǒng)的第二章,主要是介紹如何統(tǒng)計js報錯,跟著我一步步做,你也能搭建出一個屬于自己的前端監(jiān)控系統(tǒng)。

目前已經(jīng)在運行的線上Demo:前端監(jiān)控系統(tǒng)

代碼和講解都放在這篇文章里: 監(jiān)控系統(tǒng)介紹及代碼

用戶對前端程序員來說,就是一個黑匣子。 如果用戶上報了一個錯誤,前端程序員就是兩眼一抹黑,因為很多錯誤是沒法復(fù)現(xiàn)的。我問過很多前端工程師,他們的回答都是,如果你沒法復(fù)現(xiàn)Bug,我怎么去解決這個Bug呢。 那么有沒有一個辦法可以解決用戶和前端程序員之間的障礙呢, 讓用戶對我們來說,不再是黑匣子,而是透明化。用戶的頁面長什么樣,他們都做了什么操作,發(fā)生了什么錯誤,我們都能夠清晰的知道,那么,再有問題上報的時候,我就會很有信心的說一句: I Can Fix it !

最近試用了一下Fundebug,進入首頁,第一條便是 黑科技!支持錄屏。 這下就驚呆我了,js做前端監(jiān)控,居然還能錄屏? 你丫這是要逆天啊? 所以,趕緊注冊了賬號,進行試用。

經(jīng)過各種配置后,進行測試發(fā)布,發(fā)現(xiàn)毫無效果,所以詢問客服。 回答是: 目前錄制功能有bug,所以默認為關(guān)閉狀態(tài),將配置屬性silentVideo設(shè)置為false即可。(PS:Fundebug的錄屏BUG已經(jīng)修復(fù)了)

果不其然,經(jīng)過客服的細心指導(dǎo),終于成功了。 圖一為電腦版chrome瀏覽器,可以正常進行屏幕錄制。 圖二為手機app自帶的webview瀏覽器,第一次點擊顯示灰屏,第二次點擊顯示為電腦版的錄屏。經(jīng)過測試,除了chrome之外,其他瀏覽器均不支持。這讓我想起一個可以進行js截屏的庫JSCapture, 也是只支持chrome瀏覽器的。我猜想,F(xiàn)undebug用的應(yīng)該就是這個黑科技。 Fundebug也表示并非真的視頻,應(yīng)該是多做了幾幀截屏,然后順序切換,看著像視頻了。(PS:Fundebug的錄屏功能并非通過截圖實現(xiàn)的)

雖然是黑科技,但是也面臨著幾個比較大的問題:

一、因為支持的瀏覽器只有chrome,而chrome又是兼容性做得最好的瀏覽器了,很多問題在這個瀏覽器上根本不會發(fā)生, 所以這個黑科技還是有待來日,也許會得到更多瀏覽器的支持之后,才能真正的發(fā)揮作用。不得不感慨一句:唉,兼容性-前端程序員一生的宿命。(PS:Fundebug的錄屏功能并非只支持Chrome)

二、就算屏幕錄制解決了,上傳了一個至少有個幾幀的仿視頻,這個流量大小可是很嚴重問題了,雖然Fundebug說是經(jīng)過特殊處理壓縮后,一個視頻只有幾十KB,我總覺得不是很靠譜,感覺比較難以實現(xiàn)(待驗證)。(PS:Fundebug的錄屏數(shù)據(jù)經(jīng)過優(yōu)化和壓縮,因此并不大)

三、我自己的手機是iphone6 Plus, 當Fundebug在我的手機上進行屏幕捕捉的時候,手機都會卡頓很久。 我之前曾嘗試在iphone6上用js進行截圖,但是也會出現(xiàn)卡頓現(xiàn)象,這一點在微信瀏覽器上表現(xiàn)極為明顯,甚至?xí)?dǎo)致微信重新刷新頁面。 好在iphone6以上的版本,截屏的效率都很高,不會再出現(xiàn)卡頓了。(PS:Fundebug的錄屏性能經(jīng)過持續(xù)優(yōu)化)

所以,F(xiàn)undebug的黑科技是不能夠普及的,但是我們可以換個思路來記錄用戶的行為。

之前,我曾經(jīng)考慮過一個需求,記錄下用戶的每個行為,訪問頁面的截圖,點擊按鈕的局部截圖,這樣,在錯誤發(fā)生的時候,就能清清楚楚的知道用戶在頁面上做了什么,但是由于截圖上傳需要耗費的流量確實太大,所以這個想法不得不放棄了。 今天,我看了Fundebug的黑科技,卻給了一些啟發(fā)。 我將針對以上提出的三個難點,完善頁面上用戶行為追蹤功能。

用戶行為追蹤功能

一、 上傳截圖,流量消耗過大怎么辦,對圖片資源進行極致壓縮。

進行截圖后,需要上傳的數(shù)據(jù)很大,因為是圖片數(shù)據(jù),多則大幾百Kb, 少則也有個上百Kb, 這么大的流量,對用戶端,損耗確實過大。

首先,對js截圖進行了幾種測試,如圖:

以上截圖方式的參數(shù)如下:

參考 截圖方式一 截圖方式二 截圖方式三
壓縮前/后長度 28764/10787 93076/34903 168312/63118
圖片壓縮率 72% 40% 0%
截圖大小 21Kb 68.2Kb 123Kb

綜上分析,截圖方式一, 壓縮率高,雖然截圖不是很清晰,但是,也能夠看得出,線上用戶頁面是什么樣子的。

而且,也解決了,在低端機上截圖消耗性能過大的弊端,二十幾Kb的流量,也是我們完全能夠接受的大小了。

由此可見,該方式能夠完全能夠滿足我們追蹤用戶行為的需求。

二、如果用戶量非常多, 用戶頻繁的上傳,也是一個大問題

所以,我的建議是分散流量,讓每個用戶為我們貢獻至少一次頁面截圖:

① 每個用戶都在隨機的頁面,隨機的時間上傳一個頁面截圖,以及一個點擊區(qū)域截圖,有且僅上傳一次,一個用戶的生命周期中只貢獻一次頁面截圖

② 每個用戶發(fā)生某一類錯誤時,也只需上傳一個截圖即可,多個類型的錯誤,則上傳多個截圖。這樣可以大量節(jié)省用戶的上傳次數(shù)。

③ 用戶的截圖數(shù)據(jù)很大, 時間長了需要很大的硬盤空間, 所以我的建議是,每個流程頁面,只需要對應(yīng)一個(點擊區(qū)域截圖,同理)。 每個用戶的某一種類型的錯誤頁面也只對應(yīng)一個(方便定位錯誤原因)

如何截圖,如何壓縮上傳資源的大小

// js處理截圖
this.screenShot = function(cntElem, callback) {
    var shareContent = cntElem; //需要截圖的包裹的(原生的)DOM 對象
    var width = shareContent.offsetWidth; //獲取dom 寬度
    var height = shareContent.offsetHeight; //獲取dom 高度
    var canvas = document.createElement("canvas"); //創(chuàng)建一個canvas節(jié)點
    var scale = 0.6; //定義任意放大倍數(shù) 支持小數(shù)
    canvas.style.display = "none";
    canvas.width = width * scale; //定義canvas 寬度 * 縮放
    canvas.height = height * scale; //定義canvas高度 *縮放
    canvas.getContext("2d").scale(scale, scale); //獲取context,設(shè)置scale
    var opts = {
        scale: scale, // 添加的scale 參數(shù)
        canvas: canvas, //自定義 canvas
        logging: false, //日志開關(guān),便于查看html2canvas的內(nèi)部執(zhí)行流程
        width: width, //dom 原始寬度
        height: height,
        useCORS: true // 【重要】開啟跨域配置
    };
    html2canvas(cntElem, opts).then(function(canvas) {
        var dataURL = canvas.toDataURL();
        var tempCompress = dataURL.replace("data:image/png;base64,", "");
        var compressedDataURL = Base64String.compress(tempCompress);
        callback(compressedDataURL);
    });
};

要做成這件事,必須依賴兩個js庫的幫忙了。

html2Canvas 執(zhí)行html頁面截圖, lz-string 執(zhí)行對字符串長度的壓縮,使用方式,如上方代碼所示。

由于用戶行為追蹤功能可以由使用者選擇性開起, 所以,建議這兩個js庫文件有客戶端引入, 這樣就可以減少探針代碼的大小, 如此,我們就需要定義一個加載js文件的小工具

// 加載js文件的小工具
this.loadJs = function(url, callback) {
    var script = document.createElement("script");
    script.async = 1;
    script.src = url;
    script.onload = callback;
    var dom = document.getElementsByTagName("script")[0];
    dom.parentNode.insertBefore(script, dom);
    return dom;
};
// html2Canvas 庫文件加載完成后,通知全局變量,lz-string 同理
utils.loadJs("http://html2canvas.hertzen.com/dist/html2canvas.min.js", function() {
    html2CanvasLoaded = true;
});

OK, 數(shù)據(jù)都已經(jīng)準備妥當,剩下的就是要把這些數(shù)據(jù)存儲起來,并和用戶行為,以及js錯誤關(guān)聯(lián)起來。 完成用戶行為追蹤功能。

PS:本文關(guān)于Fundebug錄屏功能的內(nèi)容有些不準確的地方,比如錄屏并非通過截圖實現(xiàn)的,錄屏插件的BUG也已經(jīng)修復(fù)了,錄屏并非只支持Chrome,錄屏數(shù)據(jù)并不大,錄屏性能也優(yōu)化了很多。

關(guān)于Fundebug

Fundebug專注于JavaScript、微信小程序、微信小游戲、支付寶小程序、React Native、Node.js和Java線上應(yīng)用實時BUG監(jiān)控。 自從2016年雙十一正式上線,F(xiàn)undebug累計處理了10億+錯誤事件,付費客戶有陽光保險、核桃編程、荔枝FM、掌門1對1、微脈、青團社等眾多品牌企業(yè)。歡迎大家免費試用!

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/106038.html

相關(guān)文章

  • 步一搭建前端監(jiān)控系統(tǒng)如何記錄用戶行為?

    摘要:摘要通過記錄用戶行為,快速復(fù)現(xiàn)場景。這是搭建前端監(jiān)控系統(tǒng)的第二章,主要是介紹如何統(tǒng)計報錯,跟著我一步步做,你也能搭建出一個屬于自己的前端監(jiān)控系統(tǒng)。 摘要: 通過記錄用戶行為,快速復(fù)現(xiàn)BUG場景。 作者:一步一個腳印一個坑 原文:搭建前端監(jiān)控系統(tǒng)(備選)用戶行為統(tǒng)計和監(jiān)控篇(如何快速定位線上問題) Fundebug經(jīng)授權(quán)轉(zhuǎn)載,版權(quán)歸原作者所有。 一步一步搭建前端監(jiān)控系統(tǒng)系列博客: ...

    tolerious 評論0 收藏0
  • 步一搭建前端監(jiān)控系統(tǒng)如何定位前端線上問題?

    摘要:一直以來,前端的線上問題很難定位,因為它發(fā)生于用戶的一系列操作之后。當然,這些問題并非不能克服,讓我們來一起看看如何去定位線上的問題吧。地址參考一步一步搭建前端監(jiān)控系統(tǒng)錯誤監(jiān)控篇一步一步搭建前端監(jiān)控系統(tǒng)接口請求異常監(jiān)控篇 摘要: 記錄用戶行為,排查線上BUG。 作者:一步一個腳印一個坑 原文:如何定位前端線上問題(如何排查前端生產(chǎn)問題) Fundebug經(jīng)授權(quán)轉(zhuǎn)載,版權(quán)歸原作者所...

    aaron 評論0 收藏0
  • 步一搭建前端監(jiān)控系統(tǒng):JS錯誤監(jiān)控

    摘要:摘要徒手寫錯誤監(jiān)控。為什么用定時器呢,因為在單頁應(yīng)用中,路由的切換和地址欄的變化是無法被監(jiān)控的,我確實沒有想到特別好的辦法來監(jiān)控,所以用了這種方式,如果有人有更好的辦法,請給我留言,謝謝。 摘要: 徒手寫JS錯誤監(jiān)控。 作者:一步一個腳印一個坑 原文:搭建前端監(jiān)控系統(tǒng)(二)JS錯誤監(jiān)控篇 Fundebug經(jīng)授權(quán)轉(zhuǎn)載,版權(quán)歸原作者所有。 背景:市面上的監(jiān)控系統(tǒng)有很多,大多收費,對于...

    EdwardUp 評論0 收藏0
  • 步一搭建前端監(jiān)控系統(tǒng):接口請求異常監(jiān)控

    摘要:參考一步一步搭建前端監(jiān)控系統(tǒng)錯誤監(jiān)控篇用插件記錄網(wǎng)絡(luò)請求異常關(guān)于專注于微信小程序微信小游戲支付寶小程序和線上應(yīng)用實時監(jiān)控。 摘要: 如何監(jiān)控HTTP請求錯誤? 作者:一步一個腳印一個坑 原文:搭建前端監(jiān)控系統(tǒng)(四)接口請求異常監(jiān)控篇 Fundebug經(jīng)授權(quán)轉(zhuǎn)載,版權(quán)歸原作者所有。 背景:市面上的監(jiān)控系統(tǒng)有很多,大多收費,對于小型前端項目來說,必然是痛點。另一點主要原因是,功能雖然...

    dreamtecher 評論0 收藏0
  • 步一步教你如何搭建自己的視頻聚合站

    摘要:不過因為各個平臺互相挖人的關(guān)系,導(dǎo)致關(guān)注的一些主播分散到了各個直播平臺,來回切換有點麻煩,所以萌生了做一個視頻聚合站的想法。后續(xù)我們會對這三個部分的功能做逐一展開說明。正則處理要求比較高,但是幾乎能應(yīng)對所有的情況,屬于大殺器。 前言 作為一個爐石傳說玩家,經(jīng)常有事沒事開著直播網(wǎng)站看看大神們的精彩表演。不過因為各個平臺互相挖人的關(guān)系,導(dǎo)致關(guān)注的一些主播分散到了各個直播平臺,來回切換有點麻...

    justjavac 評論0 收藏0

發(fā)表評論

0條評論

閱讀需要支付1元查看
<