在PHP语言中,内置了数量庞大的函数,每个函数的功能不尽相同。灵活的运用这些函数可以为我们带来许多功能的实现。下面我们就介绍一下PHP error_log()函数的相关功能。

PHP error_log()函数主要是用来写错误日志的函数,我们在多人开发,或者在比较复杂,并且没有单元测试的开发项目中,完全可以使用它来记录我们程序中的错误,特别是数据库查询语句执行的错误。

我们来大致了解一下PHP error_log()函数。我们看下手册的解释:

error_log

(PHP 3, PHP 4, PHP 5)

bool error_log ( string message [, int message_type [, string destination [, string extra_headers]]] )

发送一个错误信息到Web服务器的错误日志,一个TCP的端口或者是一个文件。

我们看PHP error_log()函数的参数,***个参数message是消息内容,第二个参数type是消息类型,第三个参数是目标文件,第四个参数是其他的头信息。其实一般第四个参数都用不到,我们主要看前面三个参数,第二个参数是消息类型,包括0, 1, 2, 3等四种类型,0是默认的类型。四个类型的作用:

0

信息内容发送到PHP的系统日志记录,使用操作系统的自己的日志记录机制或一个文件,整个取决于php.ini中的配置选项error_log的内容。这是缺省选项。

1

把信息内容发送到一个邮件地址,第三个参数就是一个邮件地址,第四个参数是一个头信息发送邮件的,第二个类型使用mail()函数来发送邮件

2

消息通过PHP的调试服务器,远程的写入到某个PHP调试服务器上,当然,PHP在编译的时候--enable-debugger必须打开,另外,整个类型只是针对PHP 3有效

3

消息作为一个新行附加在一个目标文件中。其实对于我们来说,日志为了简便起见,一般直接使用类型3就比较合适了,把日志文件写到自己需要的文件中。

为了示例PHP error_log()函数的简单使用,我们个例子说明。假设我们数据库抽象类使用PEAR::DB类,现在我想在程序中记录我们的程序是否有执行错误。那么我们使用error_log()来记录我们那些SQL语句执行错误或者失败了,至少我们的PEAR::DB类提供了DB::isError()方法来获取某个执行结果对象是否有错误,那么我们就能够旁断是否执行某条SQL出现了错误,再来考虑是否记录日志,同时对象有个userinfo的属性,该属性记录了错误的SQL语句,那么我们可以构造这样一个函数:

function logError($object)

{

if(DB::isError($object))

{

error_log(date("[Y-m-d H:i:s]")

." -[".$_SERVER['REQUEST_URI'].

"] :".$object ->userinfo."\n",

3, "/tmp/php_sql_err.log");

return true;

}

return false;

}

PHP error_log()函数就是能够记录发现了错误SQL的地方,那么自动会把时间,当前页面,和错误的SQL语句信息记录到 /tmp/php_sql_err.log 文件当中,那么,当我们在调试程序的时候,发现数据提取不正确或者没有数据提取的时候,那么我们完全可以查看 /tmp/php_sql_err.log 文件来查看我们的错误页面和错误的SQL语句。

当然,我们必须在我们执行SQL查询的程序中去使用这个函数,比如我们执行一个编写一个提取新闻信息的函数:

function getNewsContent($news_id, $field="")

{

global $db;

$result= $db->getRow("SELECT

$field FROM news WHEREnews_id='$news_id'");

if (logError($result))

{

return false;

}

return $result;

}

我们在里面判断SQL是否错误,如果错误了则返回false,然后我们就可以查看日志一下,看我们的PHP error_log()函数运行是否如我们预期想象的一样。

我们执行: tail /tmp/php_sql_err.log,能看到类似于这样的信息:

[2006-01-12 11:44:34] -[/news_list.php?news_id=1] :SELECT FROM news WHERE news_id = '1' [nativecode=1064 ** You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version fo

r the right syntax to use near 'FROM news WHERE news_id = '1']

大致是因为我们select的时候,没有把需要提取的字段名写进去,那么我们就可以检查news_list.php文件,减产getNewsContent()函数法向没有传递$field参数进去,导致SQL执行错误。所以error_log()函数就帮助检查我们的SQL写的是否正确,或者是参数没有传递正确,这样大大的减轻了开发负担,想但于了对我们的程序进行了单元测试。

当然,你也可以利用PHP error_log()函数做更多记录错误日志,方便PHP开发,这个全是由自己决定。

【责任编辑:曹凯 TEL:(010)68476606】

点赞 0

php 打印mysql错误日志_PHP error_log()函数处理错误日志相关推荐

  1. php error log 函数,php日志函数error_log如何使用 php日志函数error_log用法介绍

    php日志函数error_log如何使用?这篇文章主要介绍了php日志函数error_log用法,结合实例形式分析了php日志函数error_log相关的配置文件设置.函数功能.用法与使用注意事项,需 ...

  2. php 错误记录_PHP中把错误日志保存在系统日志中(Windows系统)

    [将错误记录到系统日志中] 在 php.ini 中将 error_log 设置为: error_log = syslog 或者在运行时使用 ini_set() 函数设置. [例1] //关闭错误显示 ...

  3. mysql log error_MySQL日志之error_log

    MySQL日志类型简介 MySQL的日志大概可以分成三种,错误日志(error_log),查询日志(query_log),二进制日志(binary_log): 查询日志(query log):一般的, ...

  4. 从零构建通讯器--4.3日志打印实战,捋下main函数的调用顺序

    文章目录 一:基础设施之日志打印实战代码一 (1)新文件 (2)(//ngx_log_stderr() :三个特殊文件描述符[三章七节] (3)printf的例子说明 (4)ngx_log_stder ...

  5. 图文结合带你搞懂MySQL日志之Error Log(错误日志)

    GreatSQL社区原创内容未经授权不得随意使用,转载请联系小编并注明来源. GreatSQL是MySQL的国产分支版本,使用上与MySQL一致. 作者:KAiTO 文章来源:社区原创 往期回顾: 图 ...

  6. php mysql 500错误日志_服务器出现500错误的时候,让PHP显示错误信息

    用PHP开发程序时,如果服务器出现500的时候,如果无法知道究竟是什么原因,就无法进行调试. 要让PHP显示错误信息,可以从PHP配置文件 (php.ini)或PHP程序文件入手,另外,如果与IIS整 ...

  7. mysql 3种报错_MySQL读取Binlog日志常见的3种错误-阿里云开发者社区

    MySQL读取Binlog日志常见的3种错误 mysqlbinlog: [ERROR] unknown variable 'default-character-set=utf8mb4' 当我们在my. ...

  8. 学习笔记(03):MySQL数据库运维与管理-01-mysql通用日志与错误日志

    立即学习:https://edu.csdn.net/course/play/10084/214943?utm_source=blogtoedu MYSQL日志管理 用于实现MYSQL数据库故障排查2, ...

  9. C语言函数:错误信息打印函数,strerror()与perror()

    C语言函数:错误信息打印函数,strerror()与perror() strerror: C语言函数: 字符串函数及模拟实现strtok().strstr().strerror()_srhqwe的博客 ...

最新文章

  1. Imec推出高性能芯片的低成本冷却解决方案
  2. cookie 和 session 机制
  3. 结构损伤检测与智能诊断 陈长征_阜康危房检测价格
  4. dfs遍历和bfs遍历python_广度优先遍历(BFS)和深度优先遍历(DFS)
  5. python代码测试工具模块_详解Python中的测试工具
  6. OpenGL equirectangular等矩形环境图的实例
  7. 解决 Xcode10 编译错误 ld: library not found for -lstdc++6.0.9
  8. Java——容器(泛型)
  9. mysql cluster 宕机 恢复_mysql cluster 集群恢复不起来,还请大神赐教?报错-问答-阿里云开发者社区-阿里云...
  10. java数据导出ex_Java高级特性注解:注解实现Excel导出功能
  11. powerbi绘制地图_如何使用PowerBI绘制SQL Server 2017图形数据库
  12. angular获取路由参数_Angular应用带参数的路由实现
  13. 2018.09.02 bzoj1025: [SCOI2009]游戏(计数dp+线筛预处理)
  14. R语言---ggplot图片边缘空白设置和ggplot映射的shape值多余6个
  15. 校验码(循环冗余校验码)
  16. Win7系统怎么卸载IE浏览器
  17. 文件的三种加载方式(全网讲解最全,最严谨)
  18. 罗德里格旋转公式——旋转轴的解法之一
  19. cadence 提示lic找不到怎么办
  20. ArcGIS10从入门到精通系列实验图文教程(附配套实验数据持续更新)

热门文章

  1. linux下使用gdb调试崩溃和死锁实例
  2. VS2010配置QT5.5.0开发环境
  3. php 查找点,在多边形PHP中查找点
  4. 泛微e9隐藏明细表_泛微E8 隐藏行、明细表
  5. anaconda安装环境变量问题、python环境配置问题以及其他
  6. React Fiber 原理介绍
  7. umask及文件默认和原始权限说明
  8. EBS常用表_Dictionary
  9. 嵌入式开发之网络心跳包---阻塞和非阻塞以及是否有必要心跳包heartbeat
  10. Exchange2013DAG配置-零错误