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做的端口嗅探器--可以指定网站和端口
Oct 09 PHP
php更新修改excel中的内容实例代码
Feb 26 PHP
php.ini save_handler 修改不生效的解决办法
Jul 22 PHP
PHP采用自定义函数实现遍历目录下所有文件的方法
Aug 19 PHP
PHP+jQuery 注册模块的改进(一):验证码存入SESSION
Oct 14 PHP
DOM基础及php读取xml内容操作的方法
Jan 23 PHP
YII Framework框架教程之使用YIIC快速创建YII应用详解
Mar 15 PHP
PHP new static 和 new self详解
Feb 19 PHP
PHP房贷计算器实例代码,等额本息,等额本金
Apr 01 PHP
Laravel使用scout集成elasticsearch做全文搜索的实现方法
Nov 30 PHP
PHP反射原理与用法深入分析
Sep 28 PHP
thinkphp5 模型实例化获得数据对象的教程
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
php显示时间常用方法小结
2015/06/05 PHP
checkbox 复选框不能为空
2009/07/11 Javascript
基于JQuery的多标签实现代码
2012/09/19 Javascript
ajax与302响应代码测试
2013/10/23 Javascript
浅析JavaScript中的常用算法与函数
2013/11/21 Javascript
javascript中scrollTop详解
2015/04/13 Javascript
js获取iframe中的window对象的实现方法
2016/05/20 Javascript
javascript类型系统——undefined和null全面了解
2016/07/13 Javascript
微信小程序 require机制详解及实例代码
2016/12/14 Javascript
详解使用vscode+es6写nodejs服务端调试配置
2017/09/21 NodeJs
微信小程序实现预览图片功能
2020/10/22 Javascript
react写一个select组件的实现代码
2019/04/03 Javascript
Vue父组件如何获取子组件中的变量
2019/07/24 Javascript
详解在vue-cli3.0中自定css、js和图片的打包路径
2019/08/26 Javascript
微信小程序自定义波浪组件使用方法详解
2019/09/21 Javascript
[04:45]DOTA2-DPC中国联赛正赛 iG vs LBZS 赛后选手采访
2021/03/11 DOTA
Python 类与元类的深度挖掘 I【经验】
2016/05/06 Python
Python利用pandas计算多个CSV文件数据值的实例
2018/04/19 Python
解决python3 json数据包含中文的读写问题
2018/05/10 Python
Sanic框架基于类的视图用法示例
2018/07/18 Python
Pycharm简单使用教程(入门小结)
2019/07/04 Python
Python列表倒序输出及其效率详解
2020/03/04 Python
python实现批量修改文件名
2020/03/23 Python
基于python纯函数实现井字棋游戏
2020/05/27 Python
解决pip安装tensorflow中出现的no module named tensorflow.python 问题方法
2021/02/20 Python
anello泰国官方网站:日本流行包包品牌
2019/08/08 全球购物
网络安全方面的面试题
2016/01/07 面试题
餐饮管理自我介绍信
2014/01/15 职场文书
读书小明星事迹材料
2014/05/03 职场文书
2014离婚协议书范文两篇
2014/09/15 职场文书
开展批评与自我批评发言材料
2014/10/17 职场文书
给老婆的道歉信
2015/01/20 职场文书
2019关于实习生工作安排及待遇的管理方案!
2019/07/16 职场文书
Python中Cookies导出某站用户数据的方法
2021/05/17 Python
python 中yaml文件用法大全
2021/07/04 Python
go goroutine 怎样进行错误处理
2021/07/16 Golang