记录操作日志

在构造函数中使用注册一个会在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);
    }
}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值