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 相关文章推荐
基于mysql的bbs设计(一)
Oct 09 PHP
Php Cookie的一个使用注意点
Nov 08 PHP
php中echo()和print()、require()和include()等易混淆函数的区别
Feb 22 PHP
php中3des加密代码(完全与.net中的兼容)
Aug 02 PHP
fetchAll()与mysql_fetch_array()的区别详解
Jun 05 PHP
ThinkPHP CURD方法之data方法详解
Jun 18 PHP
PHP实现的json类实例
Jul 28 PHP
PHP之浮点数计算比较以及取整数不准确的解决办法
Jul 29 PHP
Yii2隐藏frontend/web和backend/web的方法
Dec 12 PHP
php调用云片网接口发送短信的实现方法
Oct 25 PHP
php ActiveMQ的安装与使用方法图文教程
Feb 23 PHP
如何在PHP中读写文件
Sep 07 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的session cookie错误
2009/08/09 PHP
用php随机生成福彩双色球号码的2种方法
2013/02/04 PHP
PHP获取指定函数定义在哪个文件中以及其所在的行号实例
2014/05/08 PHP
PHP小教程之实现双向链表
2014/06/12 PHP
php 处理png图片白色背景色改为透明色的实例代码
2018/12/10 PHP
很好用的js日历算法详细代码
2013/03/07 Javascript
固定表格行列(expression)在IE下适用
2013/07/25 Javascript
浅谈JavaScript函数节流
2014/12/09 Javascript
使用基于Node.js的构建工具Grunt来发布ASP.NET MVC项目
2016/02/15 Javascript
JavaScript字符串常用的方法
2016/03/10 Javascript
Node.js的npm包管理器基础使用教程
2016/05/26 Javascript
必备的JS调试技巧汇总
2016/07/20 Javascript
微信小程序 倒计时组件实现代码
2016/10/24 Javascript
在Vue项目中使用d3.js的实例代码
2018/05/01 Javascript
浅谈VUE防抖与节流的最佳解决方案(函数式组件)
2019/05/22 Javascript
vue子路由跳转实现tab选项卡
2019/07/24 Javascript
js中位数不足自动补位扩展padLeft、padRight实现代码
2020/04/06 Javascript
[00:32]2018DOTA2亚洲邀请赛出场——VP
2018/04/04 DOTA
详解Python中的装饰器、闭包和functools的教程
2015/04/02 Python
Windows上配置Emacs来开发Python及用Python扩展Emacs
2015/11/20 Python
python套接字流重定向实例汇总
2016/03/03 Python
python发送邮件功能实现代码
2016/07/15 Python
HTML中使用python屏蔽一些基本功能的方法
2017/07/07 Python
python 重定向获取真实url的方法
2018/05/11 Python
Django发送邮件和itsdangerous模块的配合使用解析
2019/08/10 Python
使用Tensorboard工具查看Loss损失率
2020/02/15 Python
python numpy库np.percentile用法说明
2020/06/08 Python
Pytest如何使用skip跳过执行测试
2020/08/13 Python
python 监控服务器是否有人远程登录(详细思路+代码)
2020/12/18 Python
JAVA的事件委托机制和垃圾回收机制
2014/09/07 面试题
非功能性需求都包括哪些方面
2013/10/29 面试题
给酒店员工的表扬信
2014/01/11 职场文书
2014年小学数学教师工作总结
2014/12/03 职场文书
个人先进事迹材料
2014/12/29 职场文书
2015迎新晚会开场白
2015/05/29 职场文书
Go结合Gin导出Mysql数据到Excel表格
2022/08/05 Golang