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

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执行调用存储过程怎么添加日志的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/89113.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月18日 02:56:07
下一篇 2025年11月18日 03:38:57

相关推荐

  • PHP会话控制:$_SESSION_变量使用错误导致输出异常如何解决?

    php 中会话控制难题解析 在学习《php和mysql web开发》第 23 章时,读者在使用会话控制时遇到了困难。 示例代码如下: session_start();$_session_[‘sess_var’] = “hello world”;echo $_session[‘sess_var’];e…

    2025年12月9日
    000
  • PHP会话控制:$_SESSION变量使用错误如何解决?

    会话控制中的错误处理 在《php和mysql web开发》第23章的练习中,使用会话控制代码遇到了一些问题,具体如下: session_start();$_session_[‘sess_var’] = “hello world”;echo $_session[‘sess_var’];echo ‘th…

    2025年12月9日
    000
  • PHP会话控制:为什么我的代码出现_SESSION_未定义的错误?

    在 php 中使用会话控制中遇到的难题 在阅读《php 和 mysql web 开发》第 23 章时,可能遇到如下代码片段: session_start();$_session_[‘sess_var’] = “hello world”;echo $_session[‘sess_var’];echo …

    2025年12月9日
    000
  • PHP无限级分类:如何实现递归查询和HTML生成?

    php 无限级分类代码和思路 什么是无限级分类? 无限级分类是一种数据结构,可以将数据组织成层级关系,可以无限层级地进行分类。 需求 立即学习“PHP免费学习笔记(深入)”; 您需要的是一种可以生成类似下图的无限级分类代码或思路: [图片:无限级分类示例] 实现思路 无线级分类通常使用递归算法来实现…

    2025年12月9日
    000
  • 想快速上手PHP开发?有哪些核心技术和学习资源推荐?

    关于PHP的核心技术与学习资料 PHP是一门广泛使用的开源服务器端脚本语言。它以其核心技术奠定了强大的基础: 面向对象编程: PHP支持面向对象的编程范式,允许开发人员创建可重用和可维护的代码。动态类型: PHP变量无需显式声明类型,使得代码更加灵活和简洁。大量的库和框架: PHP拥有丰富的库和框架…

    2025年12月9日
    000
  • 如何从数据库中获取数据并以 PHP 形式形成?

    要从 PHP 数据库中获取数据并将其显示在表单中,通常需要执行以下步骤:1.连接到数据库:使用 MySQLi 或 PDO 建立到数据库的连接。2.查询数据库:执行SQL查询以检索所需的数据。3.获取数据:从查询结果中获取数据。4.填充表单:使用获取的数据填写表单字段。 这是一个使用的简单示例MySQ…

    2025年12月9日
    000
  • Laravel 与 CodeIgniter:Web 开发的全面比较

    为您的 Web 开发项目选择正确的框架对于确保效率、可扩展性和用户满意度至关重要。 Laravel 和 CodeIgniter 是两个最流行的 PHP 框架,每个框架都提供独特的功能和优势。无论您是在英国寻找可靠的 PHP 开发公司的开发人员还是企业主,了解这些框架的细微差别都可以指导您的决定。 L…

    2025年12月9日
    000
  • (我的第一次)安装 Laravel

    有时,尤其是当您刚刚开始职业生涯时,您似乎遵循了指示却一事无成 – 而其他人似乎发现这非常容易。 这可能非常令人沮丧,我想描述一下即使在几十年之后我也经历完全相同的事情的几种方式。所以我在这里,试图详细描述我在努力让事情顺利进行时所犯的错误和失误。这是我关于这个主题的第一篇文章,但我希望…

    2025年12月9日
    000
  • PHP 与 MySQL:终极分步指南

    php 是一种语言,可让您在开发网页时灵活地连接和使用不同的数据库。有不同的数据库,既有商业的,也有免费使用的。其中,mysql 是与 php 并列最常用的数据库。 MySQL 是一个开源、免费使用的关系型数据库管理 系统(关系数据库管理系统)。它是一个快速、简单且高度可扩展的程序 因此可用于小型和…

    2025年12月9日 好文分享
    000
  • 您需要的 PHP CRUD 操作的最佳指南

    crud 操作通常在数据库上执行,因此,在本 php crud 操作教程中,您将借助 php 在 mysql 数据库上实现 crud 技术。    crud 缩写包含在关系数据库上执行的所有主要操作。它代表: c = 创建 r = 读取 u = 更新 d = 删除 你现在就会明白不同操作的详细信息。…

    2025年12月9日 好文分享
    000
  • What is CloudLinux? An Overview of the Leading Operating System for Web Hosting

    什么是CloudLinux?领先的虚拟主机操作系统概述 简介 在网络托管领域,安全性、性能和稳定性是决定托管业务成功的关键因素。 CloudLinux 是一个基于 Linux 的操作系统,专为解决共享托管环境中的这些挑战而设计。通过增强安全性、资源管理和整体系统性能,CloudLinux 已成为寻求…

    2025年12月9日
    000
  • 如何修复 Windows 上的 PHP Curl HTTPS 证书颁发机构问题

    成功的 HTTPS 请求涉及 HTTP 客户端验证 服务器根据已知且受信任的根列表提供的 TLS 证书 证书。 PHP Curl 扩展没有什么不同;卷曲 扩展使用 libcurl 发出 HTTPS 请求,而 libcurl 又使用 OpenSSL 等 TLS 库来验证请求。 Curl 扩展需要一个包…

    2025年12月9日
    000
  • php怎么去掉多余的标签

    本文针对 PHP 开发人员提供了一种高效的方法来移除不必要的 HTML 标签。通过利用内置的 DOMDocument 类和相应的 XPath 表达式,你可以轻松识别和删除多余的元素,从而优化你的 HTML 代码库,提升网页的性能和加载速度。 1. 确定要删除的标签 1.1 手动检查 检查 HTML …

    2025年12月9日
    000
  • 如何从 PHP 文本输入中查找字符串

    我们可以使用两种不同的方法以编程方式从大型文本输入字符串中定位和检索内容。 我们可以 1) 逐字搜索文本输入(相当于在文档或浏览器中使用“CTRL F”搜索),或者我们可以 2) 通过正则表达式搜索文本表达式。 使用 下面提供的代码示例,我们可以轻松利用两个 分别执行两种搜索方法的免费 API。我们…

    2025年12月9日
    000
  • 如何提高 php 水平

    提高 php 水平需要持续学习。对于成长中的 php 开发人员来说,这是一个关键阶段。以下是提高 php 技能的基本步骤: 从基础开始 专家总是建议从核心概念开始,例如变量、数据类型和控制结构。这是提高 PHP 编码技能最重要的学习路径。 创建您的工作空间 首先,创建您的开发环境作为您的创作空间。通…

    2025年12月9日
    000
  • php怎么连接mysql数据库里的数据

    使用 PHP 连接 MySQL 数据库的步骤包括:使用 mysqli_connect() 函数建立连接。执行查询,使用 mysqli_query() 函数传递 SQL 查询。处理结果,使用 mysqli_fetch_assoc()、mysqli_fetch_row() 或 mysqli_fetch_…

    2025年12月9日
    000
  • NexaPHP 简介:轻量级 MVC PHP 框架

    构建 php 应用程序通常涉及大量样板代码和组织以保持干净的结构。许多开发人员使用 laravel 或 symfony 等框架来处理此问题,但如果您只需要一个轻量级、简单的 mvc(模型-视图-控制器)框架怎么办? nexaphp 可能正是您正在寻找的。这个极简主义框架是为那些想要精益结构而没有大型…

    2025年12月9日
    000
  • 如何用php代码建表

    如何在 PHP 中使用 MySQL 创建表?连接到 MySQL 数据库。编写 CREATE TABLE 语句,指定新表及其列的结构。使用 mysqli_query() 函数执行 CREATE TABLE 语句。 如何在 PHP 中使用 MySQL 创建表 在 PHP 中使用 MySQL 创建表,需要…

    2025年12月9日
    000
  • 如何学习 PHP

    PHP 是一种编程语言,具有相对简单但通用的语法,使其成为初学者的一个很好的起点。然而,您可能仍然对第一次实现 PHP 代码的想法感到不知所措。还好,有很多 您可以用来学习 PHP 的免费资源。无论您是否观看过一些 YouTube 教程或参加在线课程,您可以快速熟悉 使用这种流行的编程语言。 在这篇…

    2025年12月9日
    300
  • 如何在 PHP CodeIgniter 中生成 Pdf sing *dompdf*

    第 1 步:创建数据库表在 mysql 数据库中创建用户表: create table users ( id int auto_increment primary key, name varchar(50) not null, surname varchar(50) not null, email …

    2025年12月9日
    000

发表回复

登录后才能评论
关注微信