码迷,mamicode.com
首页 > 数据库 > 详细

温故而知新 前端日志上传新姿势 navigator.sendBeacon(信标)

时间:2018-11-07 22:12:43      阅读:1629      评论:0      收藏:0      [点我收藏+]

标签:data   就是   send   数据   origin   ade   cti   pen   \n   

原文地址:https://mp.weixin.qq.com/s/-moAfEZicrFmun4qfWLdOQ

 

简单示例js:

var data = JSON.stringify({
  name: ‘Berwin‘
});
navigator.sendBeacon(‘http://localhost:80/index.php‘, data)

 

简单php示例:

由于是新标发送的数据是 "text/plain" 数据类型,所以用$GLOBALS[‘HTTP_RAW_POST_DATA‘]接受,由于它本来就是字符串,所以可以直接使用。

如果是GET请求,则需要用 json_encode($_REQUEST) 转换一下才可以使用示例中的WriteLog方法。

<?php 

header(‘Access-Control-Allow-Origin:*‘);
header(‘Access-Control-Allow-Headers:x-requested-with,content-type‘); 

function WriteLog($msg,$module = null,$logLevel = "DEBUG")
{
    $filepath = "./log/";
    if(!is_dir($filepath)) mkdir($filepath,‘0777‘);
    $MyLogFile = @fopen($filepath.date("Y-m-d").".txt",‘a+‘);

    $time = date("Y-m-d H:i:s");
    if(isset($module)){$module =  sprintf("\r\n归属模块:".$module."\r\n");}
    $logLine = "\r\n-------------------------------  $time -------------------------------\r\n";
    $logLine .= $module;
    $logLine .= "\r\n异常信息:$msg\r\n";
    $logLine .= "\r\n错误等级:$logLevel\r\n";
    fwrite($MyLogFile,$logLine);
}

WriteLog($GLOBALS[‘HTTP_RAW_POST_DATA‘]);

 

温故而知新 前端日志上传新姿势 navigator.sendBeacon(信标)

标签:data   就是   send   数据   origin   ade   cti   pen   \n   

原文地址:https://www.cnblogs.com/CyLee/p/9925975.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!