温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

ThinkPHP执行调用存储过程如何添加日志

发布时间:2021-01-16 11:08:02 来源:亿速云 阅读:168 作者:小新 栏目:编程语言

小编给大家分享一下ThinkPHP执行调用存储过程如何添加日志,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

ThinkPHP执行调用存储过程怎么添加日志

//PHP代码部分/**
 * [LogAdd 操作日志]
 * @param [string] $userid          [用户的ID]
 * @param [string] $type            [类型]
 * @param [string] $controller_name [当前控制器的中文名称]
 * @param [string] $function_name   [当前方法的中文名称]
 */function LogAdd($userid,$type,$controller_name,$function_name){
    //组合数据
    $data['userid'] = $userid;//当前操作的用户
    $data['type'] = $type;//当前操作的类型
    $data['url'] = 'http://'.$_SERVER['HTTP_HOST'].$_SERVER['REQUEST_URI'];//当前操作的URL地址
    $data['controller'] = CONTROLLER_NAME;//当前控制器的名称
    $data['controller_name'] = $controller_name;//当前控制器的中文名称
    $data['function'] = ACTION_NAME;//当前方法的名称
    $data['function_name'] = $function_name;//当前方法的中文名称
    $data['ip'] = getClientIP();//IP地址
    $data['create_time'] = date('Y-m-d H:i:s',time());//登录时间
    //表名
    $data_fun = 't_sys_logs_'.date('Y',time());
    //执行原生SQL
    $Model = M();
    $results = $Model->query('show tables');//打开库
    //组装为一维数组进行判断
    foreach($results as $k=>$v){
        $data_table_show[] = $v['tables_in_dbwxapplite'];
    }
    //先判断是否存在表
    if(in_array(strtolower($data_fun), $data_table_show)){
        
        //存在表直接添加日志
        $loginLog = M($data_fun)->add($data);
        if($loginLog != false){
            $res = ['status' => '1','result' => '写入成功','data' => $loginLog];
        }else{
            $res = ['status' => '0','result' => '写入失败','data' => $loginLog];
        }
    }else{
        //不存在表,先调用存储过程,在执行添加日志
        $code = $Model->query("call spCreateTableSysLogs(".date('Y',time()).")");
        if($code){
            //存储过程成功则添加数据
            $loginLog = M($data_fun)->add($data);
            if($loginLog != false){
                $res = ['status' => '1','result' => '写入成功','data' => $loginLog];
            }else{
                $res = ['status' => '0','result' => '写入失败','data' => $loginLog];
            }
        }else{
            //失败
            $res = ['status' => '0','result' => '存储过程调用失败','data' => $loginLog];
        }
    }
    return $res;}
//mysql脚本数据库部分-- ------------------------------ Table structure for t_sys_logs_2017-- ----------------------------DROP TABLE IF EXISTS `t_sys_logs_2017`;CREATE TABLE `t_sys_logs_2017` (
  `logid` int(11) NOT NULL AUTO_INCREMENT COMMENT '日志ID',
  `userid` varchar(32) NOT NULL DEFAULT '0' COMMENT '创建人ID',
  `type` varchar(8) NOT NULL COMMENT '日志操作类型,如:登录;注销;退出;修改密码;创建报名',
  `url` varchar(100) NOT NULL DEFAULT 'www' COMMENT '当前操作的URL',
  `controller` varchar(30) NOT NULL DEFAULT '控制器的名称' COMMENT '当前控制器的名称',
  `controller_name` varchar(30) NOT NULL DEFAULT '控制器的中文名称' COMMENT '当前控制器的中文名称',
  `function` varchar(30) NOT NULL DEFAULT '方法的名称' COMMENT '当前方法的名称',
  `function_name` varchar(30) NOT NULL DEFAULT '方法的中文名称' COMMENT '当前方法的中文名称',
  `ip` varchar(30) NOT NULL DEFAULT '255.255.255.255' COMMENT '当前操作客户端IP',
  `create_time` timestamp NOT NULL DEFAULT '0000-00-00 00:00:00' COMMENT '创建时间',
  `update_time` timestamp NOT NULL DEFAULT '0000-00-00 00:00:00' ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  PRIMARY KEY (`logid`)) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8mb4 COMMENT='操作日志表';

以上是“ThinkPHP执行调用存储过程如何添加日志”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注亿速云行业资讯频道!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI