window.onerror 오류 감청, 백그라운드로 보내기
var doc = document.body || document.documentElement;
var _onerror = Onerror('');
var Onerror = function(url){
this.init(url);
}
Onerror.prototype.init = function(url){
this.url = url;
this.system = this._system();
this.browser = this._browser();
this.host = location.host;
this.referrer = document.referrer;
this.path = location.pathname;
}
Onerror.prototype._system = function(){
return navigator.platform || "UNKNOW";
}
Onerror.prototype._browser = function (){
return navigator.userAgent || "UNKNOW";
};
Onerror.prototype.catchError = function ( des, path, line, word ){
if( !des ) return false;
return this.request({
description : des,
file : path,
line : line,
word : word
});
};
Onerror.prototype.request = function ( url, options ){
var self = this;
var default_settings = {
"host" : self.host,
"referrer" : self.referrer,
"path" : self.path,
"timestamp" : +new Date,
"system" : self.system,
"browser" : self.browser,
"language" : self.language
};
//beacon post
//img_beacon get
this[ ( isSupportBeacon && openBeacon ) ? "_beacon" : "_img_beacon" ]( url, $.extend( default_settings, options ));
};
Onerror.prototype._beacon = function ( url, options ){
return navigator.sendBeacon( url, JSON.stringify( options ));
};
Onerror.prototype._img_beacon = function ( url, options ){
var img = new Image();
img.src = url + "?" + Object2URLString( options );
img.onload = function (){};
return doc.appendChild( img );
};
function Object2URLString ( obj ){
var r = [];
for( var i in obj ){
r.push( i + "=" + obj[i] );
}
return r.join("&");
}
window.onerror = function (){
return _onerror.catchError(arguments);
};
node express 코드
router.get('/window-onerror/error.gif', function(req, res, next) {
var $req = getData(req),
data = $req.result,
isBeacon = $req.isBeacon;
if (!data.utmb) {
return this.res.end();
}
//insert database
console.log(data);
//beacon
if (isBeacon) {
return res.end();
}
//img beacon
else {
// http image/gif
res.writeHead('200', {'Content-Type': 'image/gif'});
//1x1 gif
return res.end('iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAADUlEQVQImWNgYGBgAAAABQABh6FO1AAAAABJRU5ErkJggg==', 'base64');
}
});
다음으로 전송:https://www.cnblogs.com/shenggen/p/5104909.html
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
다양한 언어의 JSONJSON은 Javascript 표기법을 사용하여 데이터 구조를 레이아웃하는 데이터 형식입니다. 그러나 Javascript가 코드에서 이러한 구조를 나타낼 수 있는 유일한 언어는 아닙니다. 저는 일반적으로 '객체'{}...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.