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实现的获取URL信息的类
Jan 02 PHP
PHP求最大子序列和的算法实现
Jun 24 PHP
php通过COM类调用组件的实现代码
Jan 11 PHP
浏览器关闭后,能继续执行的php函数(ignore_user_abort)
Aug 01 PHP
使用php计算排列组合的方法
Nov 13 PHP
php 邮件发送问题解决
Mar 22 PHP
ThinkPHP使用心得分享-上传类UploadFile的使用
May 15 PHP
PHP中使用sleep造成mysql读取失败的案例和解决方法
Aug 21 PHP
php执行多个存储过程的方法【基于thinkPHP】
Nov 08 PHP
PHP实现图片的等比缩放和Logo水印功能示例
May 04 PHP
PHP实现微信小程序用户授权的工具类示例
Mar 05 PHP
php弹出提示框的是实例写法
Sep 26 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/03/08 日漫
MySQL的FIND_IN_SET函数使用方法分享
2012/03/27 PHP
PHP register_shutdown_function函数的深入解析
2013/06/03 PHP
PHP制作用户注册系统
2015/10/23 PHP
非常全面的php日期时间运算汇总
2015/11/04 PHP
php+jQuery递归调用POST循环请求示例
2016/10/14 PHP
php实现文章置顶功能的方法
2016/10/20 PHP
让getElementsByName适应IE和firefox的方法
2007/09/24 Javascript
Mootools 1.2教程 同时进行多个形变动画
2009/09/15 Javascript
兼容主流浏览器的JS复制内容到剪贴板
2014/12/12 Javascript
jQuery+Ajax实现限制查询间隔的方法
2016/06/07 Javascript
手机端点击图片放大特效PhotoSwipe.js插件实现
2016/08/24 Javascript
详解Vue的computed(计算属性)使用实例之TodoList
2017/08/07 Javascript
详谈构造函数加括号与不加括号的区别
2017/10/26 Javascript
Vue.js中的computed工作原理
2018/03/22 Javascript
详解vue使用vue-layer-mobile组件实现toast,loading效果
2018/08/31 Javascript
深入理解 Koa 框架中间件原理
2018/10/18 Javascript
关于微信小程序获取小程序码并接受buffer流保存为图片的方法
2019/06/07 Javascript
ionic2.0双击返回键退出应用
2019/09/17 Javascript
vue fetch中的.then()的正确使用方法
2020/04/17 Javascript
[09:33]2015国际邀请赛第四日TOP10
2015/08/08 DOTA
[46:16]2018DOTA2亚洲邀请赛3月30日 小组赛B组 iG VS VP
2018/03/31 DOTA
[00:20]DOTA2荣耀之路7:-ah fu-抢盾
2018/05/31 DOTA
[01:07:53]RNG vs VG 2019国际邀请赛小组赛 BO2 第一场 8.15
2019/08/17 DOTA
简单介绍Python中的len()函数的使用
2015/04/07 Python
浅谈Python中的数据类型
2015/05/05 Python
浅谈python爬虫使用Selenium模拟浏览器行为
2018/02/23 Python
Tensorflow实现卷积神经网络的详细代码
2018/05/24 Python
python简易远程控制单线程版
2018/06/20 Python
使用celery和Django处理异步任务的流程分析
2020/02/19 Python
python利用xlsxwriter模块 操作 Excel
2020/10/14 Python
HTML5中图片之间的缝隙完美解决方法
2017/07/07 HTML / CSS
HomeAway的巴西品牌:Alugue Temporada
2018/04/10 全球购物
测量工程专业求职信
2014/02/24 职场文书
中学生社区服务活动报告
2015/02/05 职场文书
python 判断文件或文件夹是否存在
2022/03/18 Python