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 仿Comsenz安装效果代码打包提供下载
May 09 PHP
Wordpress 相册插件 NextGEN-Gallery 添加目录将中文转为拼音的解决办法
Dec 29 PHP
DEDE采集大师官方留后门的删除办法
Jan 08 PHP
PHP中通过HTTP_USER_AGENT判断是否为手机移动终端的函数代码
Feb 14 PHP
php版小黄鸡simsimi聊天机器人接口分享
Jan 26 PHP
PHP网页游戏学习之Xnova(ogame)源码解读(四)
Jun 23 PHP
php 使用file_get_contents读取大文件的方法
Nov 13 PHP
PHP中使用BigMap实例
Mar 30 PHP
Smarty中的注释和截断功能介绍
Apr 09 PHP
php微信开发之百度天气预报
Nov 18 PHP
PHP实现的用户注册表单验证功能简单示例
Feb 25 PHP
JS(jQuery)实现聊天接收到消息语言自动提醒功能详解【提示“您有新的消息请注意查收”】
Apr 16 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
关于IIS php调用com组件的权限问题
2012/01/11 PHP
thinkPHP框架RBAC实现原理分析
2019/02/01 PHP
Javascript中的Callback方法浅析
2015/03/15 Javascript
js实现圆盘记速表
2015/08/03 Javascript
跟我学习javascript的作用域与作用域链
2015/11/19 Javascript
js HTML5 Ajax实现文件上传进度条功能
2016/02/13 Javascript
js获取form表单所有数据的简单方法
2016/08/18 Javascript
AngularJS路由删除#符号解决的办法
2017/09/28 Javascript
react 实现页面代码分割、按需加载的方法
2018/04/03 Javascript
Vue项目实现简单的权限控制管理功能
2019/07/17 Javascript
js实现随机div颜色位置 类似满天星效果
2019/10/24 Javascript
有关vue 开发钉钉 H5 微应用 dd.ready() 不执行问题及快速解决方案
2020/05/09 Javascript
[34:08]2018DOTA2亚洲邀请赛3月29日 小组赛B组 VP VS EG
2018/03/30 DOTA
[52:52]完美世界DOTA2联赛PWL S3 LBZS vs access 第一场 12.10
2020/12/13 DOTA
详解Python中的Cookie模块使用
2015/07/06 Python
Python实现的概率分布运算操作示例
2017/08/14 Python
python获取酷狗音乐top500的下载地址 MP3格式
2018/04/17 Python
python 时间信息“2018-02-04 18:23:35“ 解析成字典形式的结果代码详解
2018/04/19 Python
python实现决策树分类
2018/08/30 Python
python3 http提交json参数并获取返回值的方法
2018/12/19 Python
Python + selenium + crontab实现每日定时自动打卡功能
2020/03/31 Python
JupyterNotebook 输出窗口的显示效果调整方法
2020/04/13 Python
基于Python实现视频的人脸融合功能
2020/06/12 Python
使用CSS Grid布局实现网格的流动
2014/12/30 HTML / CSS
jurlique茱莉蔻英国官网:澳洲天然护肤品
2018/08/03 全球购物
英国最受欢迎的平价女士时装零售商:Roman Originals
2019/11/02 全球购物
教师演讲稿范文
2014/01/08 职场文书
家长学校培训材料
2014/08/20 职场文书
2014年教师节演讲稿
2014/09/03 职场文书
现实表现材料范文
2014/12/23 职场文书
综合测评自我评价
2015/03/06 职场文书
2015年库房工作总结
2015/04/30 职场文书
教师法制教育培训学习心得体会
2016/01/14 职场文书
高三英语教学反思
2016/03/03 职场文书
关于Nginx中虚拟主机的一些冷门知识小结
2022/03/03 Servers
CSS 鼠标点击拖拽效果的实现代码
2022/12/24 HTML / CSS