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 相关文章推荐
我的论坛源代码(九)
Oct 09 PHP
php下关于中英数字混排的字符串分割问题
Apr 06 PHP
PHP转换文件夹下所有文件编码的实现代码
Jun 06 PHP
浅析PHP 按位与或 (^ 、&amp;)
Jun 21 PHP
基于PHP创建Cookie数组的详解
Jul 03 PHP
PHP5各个版本的新功能和新特性总结
Mar 16 PHP
dedecms中使用php语句指南
Nov 13 PHP
Web程序工作原理详解
Dec 25 PHP
mysql查找删除重复数据并只保留一条实例详解
Sep 24 PHP
thinkPHP中session()方法用法详解
Dec 08 PHP
PHP模糊查询技术实例分析【附源码下载】
Mar 07 PHP
Laravel 前端资源配置教程
Oct 18 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
苏联队长,苏联超人蝙蝠侠,这些登场的“山寨”英雄真的很严肃
2020/04/09 欧美动漫
用php实现批量查询清除一句话后门的代码
2008/01/20 PHP
php session 预定义数组
2009/03/16 PHP
PHP下对字符串的递增运算代码
2010/08/21 PHP
PHP 读取Postgresql中的数组
2013/04/14 PHP
PHP解耦的三重境界(浅谈服务容器)
2017/03/13 PHP
PHP实现的mysql主从数据库状态检测功能示例
2017/07/20 PHP
thinkPHP5框架中widget的功能与用法详解
2018/06/11 PHP
原型方法的不同写法居然会影响调试的解决方法
2007/03/08 Javascript
使用js实现按钮控制文本框加1减1应用于小时+分钟
2013/12/09 Javascript
Javascript iframe交互并兼容各种浏览器的解决方法
2016/07/12 Javascript
bootstrap警告框使用方法解析
2017/01/13 Javascript
JS实现本地存储信息的方法(基于localStorage与userData)
2017/02/18 Javascript
echart简介_动力节点Java学院整理
2017/08/11 Javascript
值得收藏的八个常用的js正则表达式
2018/10/19 Javascript
vue.js的状态管理vuex中store的使用详解
2019/11/08 Javascript
uni-app如何实现增量更新功能
2020/01/03 Javascript
原生javascript如何实现共享onload事件
2020/07/03 Javascript
[02:25]DOTA2英雄基础教程 熊战士
2014/01/03 DOTA
Python的Flask框架及Nginx实现静态文件访问限制功能
2016/06/27 Python
python中的for循环
2018/09/28 Python
使用Python获取并处理IP的类型及格式方法
2018/11/01 Python
Python使用requests xpath 并开启多线程爬取西刺代理ip实例
2020/03/06 Python
Python如何获取文件指定行的内容
2020/05/27 Python
在keras中model.fit_generator()和model.fit()的区别说明
2020/06/17 Python
python使用opencv resize图像不进行插值的操作
2020/07/05 Python
对python中list的五种查找方法说明
2020/07/13 Python
HTML5 Canvas玩转酷炫大波浪进度图效果实例(附demo)
2016/12/14 HTML / CSS
美国瑜伽品牌:Gaiam
2017/10/31 全球购物
远东集团网络工程师面试题
2014/10/20 面试题
安全生产管理合理化建议书
2014/03/12 职场文书
单位工程竣工验收方案
2014/03/16 职场文书
文化建设工作方案
2014/05/12 职场文书
2014年财政工作总结
2014/12/10 职场文书
高中生打架检讨书1000字
2015/02/17 职场文书
小程序实现文字循环滚动动画
2021/06/14 Javascript