PHP error_log()将错误信息写入一个文件(定义和用法)


Posted in PHP onOctober 25, 2013

在php程序编写中,养成写入log文件的编程习惯,是一个很好的编程习惯,程序员都应该学会这种编程思想,不要太浮躁。前期编程的不严谨,往往会带来后期维护和调式的困难,付出的时间和精力将会更多。
error_log() 是发送错误信息到某个地方的一个函数,在程序编程中比较常见,尤其是在程序调试阶段。
本文将用实例讲解一下error_log()这个函数的用法,以及一些需要注意的问题。

<?php
$str='这是条错误信息。';
error_log($str,3,'errors.log');
?>

上述是最常用的error_log()例子,它的作用是把一条信息写入errors.log这个文件里,这个文件如果不存在则自动创建。在这个例子中,我们看到有一个参数“3”,注意这个数字“3”不能更改也不能去掉。
下面列举一下使用error_log()这个函数的过程中可能出现的问题:
(1)程序报错提示:Warning: error_log() [function.error-log]: failed to open stream: Permission denied in ...on line ...
上述错误的出现,是因为文件没有写权限,开启该目录的文件写权限即可。
(2)写入到log文件中的信息不能换行
使用error_log()写入log文件,会发现文字是没有换行的,可以对以上代码做如下改进:
<?php
$str="这是条错误信息。\r\n";
error_log($str,3,'errors.log');
?>

注意$str,用的是双引号(php单引号和双引号的区别),还在字符串结尾加上了\r\n。这跟第一个实例那个写法是不同的。
下面对error_log()函数做一些介绍
格式
bool error_log ( string $message [, int $message_type=0 [, string $destination [, string $extra_headers ]]] )
把错误信息发送到 web 服务器的错误日志,或者到一个文件里。
message     应该被记录的错误信息。
message_type
设置错误应该发送到何处。使用 操作系统的日志机制或者一个文件,取决于 error_log 指令设置了什么。可能的信息类型有以下几个:
 0 message 发送到 PHP 的系统日志。 这是个默认的选项。iis服务器运行调试php程序错误信息生成log文件在哪里。
 1 message 发送到参数 destination 设置的邮件地址。 第四个参数 extra_headers 只有在这个类型里才会被用到。
 2 不再是一个选项。
 3 message 被发送到位置为 destination 的文件里。 字符 message 不会默认被当做新的一行,而是追加到行末。
 4 message 直接发送到 SAPI 的日志处理程序中。
destination 目标。它的含义描述于以上,由 message_type 参数所决定。
extra_headers 额外的头。当 message_type 设置为 1 的时候使用。 该信息类型使用了 mail() 的同一个内置函数。

返回值   成功时返回 TRUE, 或者在失败时返回 FALSE。

再来个例子

发送一封带有自定义错误的电子邮件:
<?php
$test=2; if ($test>1) {
error_log("A custom error has been triggered", 1,"someone@example.com","From: webmaster@example.com"); 
} 
?>

输出:
A custom error has been triggered
PHP 相关文章推荐
PHP 面向对象程序设计(oop)学习笔记(一) - 抽象类、对象接口、instanceof 和契约式编程
Jun 12 PHP
php中PDO方式实现数据库的增删改查
May 17 PHP
使用Thinkphp框架开发移动端接口
Aug 05 PHP
详解Window7 下开发php扩展
Dec 31 PHP
PHP自带方法验证邮箱是否存在
Feb 01 PHP
laravel中的错误与日志用法详解
Jul 26 PHP
PHP针对多用户实现更换头像功能
Sep 04 PHP
PHP数组操作实例分析【添加,删除,计算,反转,排序,查找等】
Dec 24 PHP
php实现简单加入购物车功能
Mar 07 PHP
php二维码生成以及下载实现
Sep 28 PHP
PHP格式化显示时间date()函数代码
Oct 03 PHP
php实现银联商务公众号+服务窗支付的示例代码
Oct 12 PHP
php获取目录所有文件并将结果保存到数组(实例)
Oct 25 #PHP
php中并发读写文件冲突的解决方案
Oct 25 #PHP
ajax返回值中有回车换行、空格的解决方法分享
Oct 24 #PHP
学习php分页代码实例
Oct 24 #PHP
获取URL文件名后缀
Oct 24 #PHP
关于php程序报date()警告的处理(date_default_timezone_set)
Oct 22 #PHP
php 修改、增加xml结点属性的实现代码
Oct 22 #PHP
You might like
成为好程序员必须避免的5个坏习惯
2014/07/04 PHP
获取服务器传来的数据 用JS去空格的正则表达式
2012/03/26 Javascript
如何用js控制frame的隐藏或显示的解决办法
2013/03/20 Javascript
动态获取复选框checkbox选中个数的jquery代码
2013/06/25 Javascript
jQuery中append()方法用法实例
2014/12/25 Javascript
jQuery插件slicebox实现3D动画图片轮播切换特效
2015/04/12 Javascript
原生js制作日历控件实例分享
2016/04/06 Javascript
JS对象深度克隆实例分析
2017/03/16 Javascript
使用vue-cli编写vue插件的方法
2018/02/26 Javascript
webpack v4 从dev到prd的方法
2018/04/02 Javascript
VUE实时监听元素距离顶部高度的操作
2020/07/29 Javascript
js实现数字跳动到指定数字
2020/08/25 Javascript
利用Python爬取可用的代理IP
2016/08/18 Python
人脸识别经典算法一 特征脸方法(Eigenface)
2018/03/13 Python
Python中的支持向量机SVM的使用(附实例代码)
2019/06/26 Python
python按比例随机切分数据的实现
2019/07/11 Python
Python3实现监控新型冠状病毒肺炎疫情的示例代码
2020/02/13 Python
基于python 等频分箱qcut问题的解决
2020/03/03 Python
Python + selenium + crontab实现每日定时自动打卡功能
2020/03/31 Python
python中matplotlib实现随鼠标滑动自动标注代码
2020/04/23 Python
Python 必须了解的5种高级特征
2020/09/10 Python
迪斯尼假期(欧洲、中东及非洲):Disney Holidays EMEA
2021/02/15 全球购物
eDreams德国:南欧领先的在线旅游公司
2020/12/07 全球购物
秋季运动会通讯稿
2014/01/24 职场文书
办公设备采购方案
2014/03/16 职场文书
注册资产评估专业求职信
2014/07/16 职场文书
学校党的群众路线教育实践活动制度建设计划
2014/11/03 职场文书
优秀团员自我评价
2015/03/10 职场文书
入党积极分子党小组意见
2015/06/02 职场文书
《静夜思》教学反思
2016/02/17 职场文书
python3实现Dijkstra算法最短路径的实现
2021/05/12 Python
Python实现8种常用抽样方法
2021/06/27 Python
MySQL 分区表中分区键为什么必须是主键的一部分
2022/03/17 MySQL
MySQL 外连接语法之 OUTER JOIN
2022/04/09 MySQL
vue如何清除浏览器历史栈
2022/05/25 Vue.js
win10壁纸在哪个文件夹 win10桌面背景图片文件位置分享
2022/08/05 数码科技