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版(1)
Oct 09 PHP
PHP面向对象分析设计的经验原则
Sep 20 PHP
PHP定时自动生成静态HTML的实现代码
Jun 20 PHP
php批量缩放图片的代码[ini参数控制]
Feb 11 PHP
解析php中var_dump,var_export,print_r三个函数的区别
Jun 21 PHP
简单实用的.net DataTable导出Execl
Oct 28 PHP
php按字符无乱码截取中文的方法
Mar 27 PHP
php实现插入排序
Mar 29 PHP
非常实用的php验证码类
May 15 PHP
PHP文件上传、客户端和服务器端加限制、抓取错误信息、完整步骤解析
Jan 12 PHP
php+redis实现商城秒杀功能
Nov 19 PHP
利用PHP内置SERVER开启web服务(本地开发使用)
Jan 22 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
载入进度条 效果
2006/07/08 Javascript
跟我一起学写jQuery插件开发方法(附完整实例及下载)
2010/04/01 Javascript
基于jquery的15款幻灯片插件
2011/04/10 Javascript
js css后面所带参数含义介绍
2013/08/18 Javascript
jQuery的DOM操作之删除节点示例
2014/01/03 Javascript
基于 Docker 开发 NodeJS 应用
2014/07/30 NodeJs
JavaScript实现网页对象拖放功能的方法
2015/04/15 Javascript
javascript实现行拖动的方法
2015/05/27 Javascript
jquery-tips悬浮提示插件分享
2015/07/31 Javascript
jquery动画效果学习笔记(8种效果)
2015/11/13 Javascript
JavaScript编写点击查看大图的页面半透明遮罩层效果实例
2016/05/09 Javascript
jQuery插件uploadify实现ajax效果的图片上传
2016/06/18 Javascript
让编辑器支持word复制黏贴、截屏的js代码
2016/10/17 Javascript
nodeJs链接Mysql做增删改查的简单操作
2017/02/04 NodeJs
详解vue2.0的Element UI的表格table列时间戳格式化
2017/06/13 Javascript
jQuery实现动态给table赋值的方法示例
2017/07/04 jQuery
JS中getElementsByClassName与classList兼容性问题解决方案分析
2019/08/07 Javascript
[47:20]DAC2018 4.4 淘汰赛 Optic vs Mineski 第一场
2018/04/05 DOTA
Python实现的选择排序算法示例
2017/11/29 Python
Python给你的头像加上圣诞帽
2018/01/04 Python
深入了解Python中pop和remove的使用方法
2018/01/09 Python
Python3.5实现的三级菜单功能示例
2019/03/25 Python
python环境路径配置以及命令行运行脚本
2019/04/02 Python
django foreignkey外键使用的例子 相当于left join
2019/08/06 Python
wxpython自定义下拉列表框过程图解
2020/02/14 Python
DataFrame 数据合并实现(merge,join,concat)
2020/06/14 Python
PyTorch之nn.ReLU与F.ReLU的区别介绍
2020/06/27 Python
俄罗斯旅游网站:Tripadvisor俄罗斯
2017/03/21 全球购物
Harman Audio官方商店:购买JBL、Harman Kardon、Infinity和AKG
2019/12/05 全球购物
一份比较全的PHP面试题
2016/07/29 面试题
三年大学自我鉴定
2014/01/16 职场文书
高校十八大报告感想
2014/01/27 职场文书
五年级学生评语
2014/04/22 职场文书
优秀毕业生的求职信
2014/07/21 职场文书
2015年家长学校工作总结
2015/04/22 职场文书