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中进行身份认证
Oct 09 PHP
php面向对象全攻略 (十) final static const关键字的使用
Sep 30 PHP
解析php中eclipse 用空格替换 tab键
Jun 24 PHP
PHP自带函数给数字或字符串自动补齐位数
Jul 29 PHP
自己写的php中文截取函数mb_strlen和mb_substr
Feb 09 PHP
php生成图片缩略图的方法
Apr 07 PHP
Zend Framework教程之前端控制器Zend_Controller_Front用法详解
Mar 07 PHP
php使用curl通过代理获取数据的实现方法
May 16 PHP
使用PHPExcel实现数据批量导出为excel表格的方法(必看)
Jun 09 PHP
PHP实现的自定义图像居中裁剪函数示例【测试可用】
Aug 11 PHP
PHP如何实现订单的延时处理详解
Dec 30 PHP
php面向对象重点知识分享
Sep 27 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/06/02 PHP
Laravel 5 框架入门(四)完结篇
2015/04/09 PHP
php简单截取字符串代码示例
2016/10/19 PHP
php 生成签名及验证签名详解
2016/10/26 PHP
模拟用户操作Input元素,不会触发相应事件
2007/05/11 Javascript
jQuery判断元素是否是隐藏的代码
2011/04/24 Javascript
jquery序列化form表单使用ajax提交后处理返回的json数据
2014/03/03 Javascript
javascript闭包传参和事件的循环绑定示例探讨
2014/04/17 Javascript
javascript作用域和闭包使用详解
2014/04/25 Javascript
JQuery以JSON方式提交数据到服务端示例代码
2014/05/05 Javascript
js+html5绘制图片到canvas的方法
2015/06/05 Javascript
node.js express安装及示例网站搭建方法(分享)
2016/08/22 Javascript
在JavaScript中调用Java类和接口的方法
2016/09/07 Javascript
bootstrap组件之按钮式下拉菜单小结
2017/01/19 Javascript
ES6中参数的默认值语法介绍
2017/05/03 Javascript
简单实现jQuery弹幕效果
2017/05/06 jQuery
详解微信第三方小程序代开发
2017/06/23 Javascript
vue.js中父组件调用子组件的内部方法示例
2017/10/22 Javascript
CentOS环境中MySQL修改root密码方法
2018/01/07 Javascript
JS实现指定区域的全屏显示功能示例
2019/04/25 Javascript
JavaScript数组常用的增删改查与其他属性详解
2020/10/13 Javascript
[02:11]2016国际邀请赛中国区预选赛全程回顾
2016/07/01 DOTA
tensorflow 变长序列存储实例
2020/01/20 Python
Tensorflow限制CPU个数实例
2020/02/06 Python
Python3 ffmpeg视频转换工具使用方法解析
2020/08/10 Python
Python logging自定义字段输出及打印颜色
2020/11/30 Python
linux系统下pip升级报错的解决方法
2021/01/31 Python
Python 带星号(* 或 **)的函数参数详解
2021/02/23 Python
大学生求职简历的自我评价范文
2013/10/12 职场文书
国际贸易专业个人鉴定
2014/02/22 职场文书
3分钟演讲稿
2014/04/30 职场文书
党的群众路线领导班子整改方案
2014/09/27 职场文书
党员组织生活会发言材料
2014/10/17 职场文书
2014年会计个人工作总结
2014/11/24 职场文书
报名委托书
2015/01/29 职场文书
苹果M1芯片安装nginx 并且部署vue项目步骤详解
2021/11/20 Servers