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执行调用存储过程怎么添加日志的详细内容。更多信息请关注PHP中文网其他相关文章!

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

运行 ThinkPHP 项目需要:安装 Composer;使用 Composer 创建项目;进入项目目录,执行 php bin/console serve;访问 http://localhost:8000 查看欢迎页面。

ThinkPHP 拥有多个版本,针对不同 PHP 版本而设计。主要版本包括 3.2、5.0、5.1 和 6.0,而次要版本用于修复 bug 和提供新功能。当前最新稳定版本为 ThinkPHP 6.0.16。在选择版本时,需考虑 PHP 版本、功能需求和社区支持。建议使用最新稳定版本以获得最佳性能和支持。

ThinkPHP Framework 的本地运行步骤:下载并解压 ThinkPHP Framework 到本地目录。创建虚拟主机(可选),指向 ThinkPHP 根目录。配置数据库连接参数。启动 Web 服务器。初始化 ThinkPHP 应用程序。访问 ThinkPHP 应用程序 URL 运行。

Laravel 和 ThinkPHP 框架的性能比较:ThinkPHP 性能通常优于 Laravel,专注于优化和缓存。Laravel 性能良好,但对于复杂应用程序,ThinkPHP 可能更适合。

《开发建议:如何利用ThinkPHP框架实现异步任务》随着互联网技术的迅猛发展,Web应用程序对于处理大量并发请求和复杂业务逻辑的需求也越来越高。为了提高系统的性能和用户体验,开发人员常常会考虑利用异步任务来执行一些耗时操作,比如发送邮件、处理文件上传、生成报表等。在PHP领域,ThinkPHP框架作为一款流行的开发框架,提供了一些便捷的方式来实现异步任务。

ThinkPHP 安装步骤:准备 PHP、Composer、MySQL 环境。使用 Composer 创建项目。安装 ThinkPHP 框架及依赖项。配置数据库连接。生成应用代码。启动应用并访问 http://localhost:8000。

ThinkPHP 是一款高性能的 PHP 框架,具备缓存机制、代码优化、并行处理和数据库优化等优势。官方性能测试显示,它每秒可处理超过 10,000 个请求,实际应用中被广泛用于京东商城、携程网等大型网站和企业系统。

开发建议:如何利用ThinkPHP框架进行API开发随着互联网的不断发展,API(ApplicationProgrammingInterface)的重要性也日益凸显。API是不同应用程序之间进行通信的桥梁,它可以实现数据共享、功能调用等操作,为开发者提供了相对简单和快速的开发方式。而ThinkPHP框架作为一款优秀的PHP开发框架,具有高效、可扩展和易用
