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(2)
Oct 09 PHP
信用卡效验程序
Oct 09 PHP
PHP Session变量不能传送到下一页的解决方法
Nov 27 PHP
php ctype函数中文翻译和示例
Mar 21 PHP
PHP 面向对象程序设计(oop)学习笔记 (五) - PHP 命名空间
Jun 12 PHP
ThinkPHP整合百度Ueditor图文教程
Oct 21 PHP
php四种定界符详解
Feb 16 PHP
Mac系统完美安装PHP7详细教程
Jun 06 PHP
php-msf源码详解
Dec 25 PHP
PHP删除数组中指定值的元素常用方法实例分析【4种方法】
Aug 21 PHP
PHP的PDO事务与自动提交
Jan 24 PHP
PHP根据key删除数组中指定的元素
Feb 28 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
全国FM电台频率大全 - 9 上海市
2020/03/11 无线电
德生PL990的分析评价
2021/03/02 无线电
php自动注册登录验证机制实现代码
2011/12/20 PHP
PHP curl 或 file_get_contents 获取需要授权页面的方法
2017/05/05 PHP
PHP使用标准库spl实现的观察者模式示例
2018/08/04 PHP
PHP常用正则表达式精选(推荐)
2019/05/28 PHP
推荐一些非常不错的javascript学习资源站点
2007/08/29 Javascript
Javascript设置对象的ReadOnly属性(示例代码)
2013/12/25 Javascript
网页右下角弹出窗体实现代码
2014/06/05 Javascript
详解javascript遍历方式
2015/11/11 Javascript
JSP防止网页刷新重复提交数据的几种方法
2016/11/19 Javascript
react-router实现跳转传值的方法示例
2017/05/27 Javascript
vue.js实现备忘录功能的方法
2017/07/10 Javascript
Angular4 中内置指令的基本用法
2017/07/31 Javascript
Mac中安装nvm的教程分享
2017/12/11 Javascript
vue.js使用代理和使用Nginx来解决跨域的问题
2018/02/03 Javascript
JavaScript获取移动设备型号的实现代码(JS获取手机型号和系统)
2018/03/10 Javascript
bootstrap treeview 树形菜单带复选框及级联选择功能
2018/06/08 Javascript
jQuery实现的点击按钮改变样式功能示例
2018/07/21 jQuery
JavaScript面向对象核心知识与概念归纳整理
2020/05/09 Javascript
Python中property属性实例解析
2018/02/10 Python
Python使用分布式锁的代码演示示例
2018/07/30 Python
Python Selenium 之关闭窗口close与quit的方法
2019/02/13 Python
Python字典遍历操作实例小结
2019/03/05 Python
keras的load_model实现加载含有参数的自定义模型
2020/06/22 Python
纯CSS3代码实现switch滑动开关按钮效果
2016/08/30 HTML / CSS
CSS3实现swap交换动画
2016/01/19 HTML / CSS
澳大利亚药房在线:ThePharmacy
2017/10/04 全球购物
服装店营销方案
2014/03/10 职场文书
年终总结会主持词
2014/03/25 职场文书
房地产公司见习自我鉴定
2014/04/28 职场文书
高等教育学专业自荐书
2014/06/17 职场文书
2015年信息宣传工作总结
2015/05/26 职场文书
法人代表证明书范本
2015/06/18 职场文书
表彰大会新闻稿
2015/07/17 职场文书
Python下opencv库的安装过程及问题汇总
2021/06/11 Python