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 相关文章推荐
如何限制访问者的ip(PHPBB的代码)
Oct 09 PHP
PHP中HTTP方式下的Gzip压缩传输方法举偶
Feb 15 PHP
php方法调用模式与函数调用模式简例
Sep 20 PHP
PHP 异步执行方法,模拟多线程的应用分析
Jun 03 PHP
php面向对象中static静态属性与方法的内存位置分析
Feb 08 PHP
Codeigniter实现发送带附件的邮件
Mar 19 PHP
PHP模板解析类实例
Jul 09 PHP
php简单判断两个字符串是否相等的方法
Jul 13 PHP
举例讲解PHP面对对象编程的多态
Aug 12 PHP
Yii净化器CHtmlPurifier用法示例(过滤不良代码)
Jul 15 PHP
PHP7 字符串处理机制修改
Mar 09 PHP
详解Laravel服务容器的优势
May 29 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
PHP内核介绍及扩展开发指南―基础知识
2011/09/11 PHP
PHP版微信公众平台红包API
2015/04/02 PHP
使用PHP编写发红包程序
2015/07/22 PHP
详解laravel安装使用Passport(Api认证)
2018/07/27 PHP
在Javascript中定义对象类别
2006/12/22 Javascript
offsetParent 算法分析
2010/04/05 Javascript
javascript 判断中文字符长度的函数代码
2012/08/27 Javascript
使用jquery中height()方法获取各种高度大全
2014/04/02 Javascript
jQuery的基本概念与高级编程
2015/05/14 Javascript
javascript实现rgb颜色转换成16进制格式
2015/07/10 Javascript
Node.js程序中的本地文件操作用法小结
2016/03/06 Javascript
关于Vue.js一些问题和思考学习笔记(1)
2016/12/02 Javascript
vue与TypeScript集成配置最简教程(推荐)
2017/10/17 Javascript
关于vue单文件中引用路径的处理方法
2018/01/08 Javascript
总结javascript三元运算符知识点
2018/09/28 Javascript
微信小程序列表时间戳转换实现过程解析
2019/10/12 Javascript
webpack+express实现文件精确缓存的示例代码
2020/06/11 Javascript
JavaScript实现简单日历效果
2020/09/11 Javascript
梳理一下vue中的生命周期
2020/12/30 Vue.js
python BeautifulSoup使用方法详解
2013/11/21 Python
探究Python多进程编程下线程之间变量的共享问题
2015/05/05 Python
Scrapy的简单使用教程
2017/10/24 Python
Python实现的redis分布式锁功能示例
2018/05/29 Python
python-tkinter之按钮的使用,开关方法
2019/06/11 Python
keras自定义损失函数并且模型加载的写法介绍
2020/06/15 Python
PyTorch预训练Bert模型的示例
2020/11/17 Python
45个非常奇妙的CSS3 特性应用示例
2012/01/01 HTML / CSS
中学教师实习自我鉴定
2013/09/28 职场文书
校园安全广播稿
2014/02/08 职场文书
历史专业大学生职业生涯规划书
2014/03/13 职场文书
品质标语大全
2014/06/21 职场文书
安全伴我行演讲稿
2014/09/04 职场文书
火烧圆明园观后感
2015/06/03 职场文书
预备党员表决心的话
2015/09/22 职场文书
关于flex 上下文中自动 margin的问题(完整例子)
2021/05/20 HTML / CSS
NoSQL优缺点与MongoDB数据库简介
2022/06/05 MongoDB