监控平台之上报(未完成)

上报方式:

// 发送图片数据

// 普通ajax发送请求数据

// sendBeacon,如果不兼容,再使用图片上传

科普小知识:

一般token生成,hash生成的格式,是36进制,也就是0至9和A至Z

Math.random().toString(36).substring(2, 9)

// '0bz4xls' 'o0hcuwy'

import config from './config'

// 一般token生成,hash生成的格式,是36进制
// 0至9和A至Z
// Math.random().toString(36).substring(2, 9)

// xhr获取
export const originalProto = XMLHttpRequest.prototype;
export const originalSend = originalProto.send;
export const originalOpen = originalProto.open;

// 生成唯一上报id
export default function generateUniqueId() {
    return 'id-' + Date.now() + '-' + Math.random().toString(36).substring(2, 9)
}

// 上报函数
export function report(data) {
    if (!config.report) {
        console.error('请设置上传 url 地址');
    }

    const reporData = JSON.stringify({
        id: generateUniqueId(),
        data
    });
    // TODO 发送数据 优先使用 secdBeacon,如果不兼容,再使用图片上传
    const value = beaconRequest(config.url, reporData)
    if (!value) {
        // 上报数据,使用图片的方式
        config.isImageUpload ? imgRequest(reporData) : xhrRequest(config.url, reporData); 
    }
}

// 发送图片数据 
export function imgRequest(data) {
    const img = new Image();
    img.src =  `${config.url}?data=${encodeURIComponent(JSON.stringify(data))}`;
}

// 普通ajax发送请求数据
export function xhrRequest(url, data) {
    let flag = true
    if(window.requestIdleCallback){
        return flag = window.requestIdleCallback(()=>{
            const xhr = new XMLHttpRequest();
            originalOpen.call(xhr, 'POST', data.url, true);
            originalSend.call(xhr, JSON.stringify(data));
        },{ timeout: 3000 });
    } else {
        setTimeout(()=>{
            const xhr = new XMLHttpRequest();
            originalOpen.call(xhr, 'POST', data.url, true);
            originalSend.call(xhr, JSON.stringify(data));
        });
    }

    const xhr = new XMLHttpRequest();
    originalOpen.call(xhr, 'POST', data.url, true);
    originalSend.call(xhr, JSON.stringify(data));
}

// sendBeacon上报方式
export function isSupportSendBeacon(){
    return 'sendBeacon' in navigator;
}
// const sendBeacon = isSupportSendBeacon()? navigator.sendBeacon: xhrRequest
// beacon发送请求数据(存在兼容性)
export function beaconRequest(data){
    let flag = true
    if(window.requestIdleCallback){
        return flag = window.requestIdleCallback(()=>{
            sendBeacon(config.url ,data);
        },{ timeout: 3000 });
    } else {
        return flag = setTimeout(()=>{
            sendBeacon(config.url, data)
        });
    }

}
相关推荐
学步_技术22 天前
自动驾驶系列—自动驾驶系统监控平台:保障无人驾驶安全的幕后英雄
人工智能·安全·自动驾驶·监控平台
dlnu20152506222 个月前
监控平台之nodejs模拟后端接口
前端·监控平台
威迪斯特5 个月前
视频监控汇聚平台:接入不同品牌的监控视频,同时把所有的监控视频接到不同的上级视频监控平台(第三方平台)
音视频·视频汇聚·28181·接入平台·监控平台·政务云·主动注册