在构造函数中使用注册一个会在php中止时执行的函数register_shutdown_function(), TP5框架中使用
$request = \think\Request::instance();
if ($request->controller() == "School" && $request->action() == "schoolarc") {
register_shutdown_function(function() {
BM('Errorlog')->uploadLog();
});
}
<?php
use think\Db;
class Errorlog{
/**
* [getDeviceType 获取途径]
* Fri 2017/12/8
*/
public function getDeviceType()
{
$_return = '';
if(!isset($_SERVER['HTTP_USER_AGENT'])) return 'other';
if(strpos($_SERVER['HTTP_USER_AGENT'], 'iPhone')||strpos($_SERVER['HTTP_USER_AGENT'], 'iPad')){
$_return = 'IOS';
}else if(strpos($_SERVER['HTTP_USER_AGENT'], 'Android')){
$_return = 'Android';
}else{
$_return = 'other';
}
return $_return;
}
/**
* [ClientIp 获取ip地址]
* Fri 2017/12/8
*/
public function ClientIp()
{
return isset($_SERVER['REMOTE_ADDR']) ? $_SERVER['REMOTE_ADDR'] : 'unknown' ;
}
/**
* [uploadLog 上传错误日志]
* Fri 2017/12/8
*/
public function uploadLog()
{
global $GLOBALS;
$err_data = [
'ip' => $this->ClientIp(),
'user_agent' => $this->getDeviceType(),
'user_name' => $GLOBALS['user_name'],
'description' => $GLOBALS['error'],
'is_success' => ($GLOBALS['error'] == "上传成功") ? 1: 0,
'update_time' => time(),
];
//file_put_contents("a.txt", var_export($err_data, true));
Db::table('upload_log')->insert($err_data);
}
}