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注入点构造代码
Jun 14 PHP
PHP 上传文件大小限制
Jul 05 PHP
PHP无限分类(树形类)的深入分析
Jun 02 PHP
php导入导出excel实例
Oct 25 PHP
Yii中使用PHPExcel导出Excel的方法
Dec 26 PHP
php将字符串随机分割成不同长度数组的方法
Jun 01 PHP
php动态变量定义及使用
Jun 10 PHP
自写的利用PDO对mysql数据库增删改查操作类
Feb 19 PHP
thinkphp5 migrate数据库迁移工具
Feb 20 PHP
PHP获取日期对应星期、一周日期、星期开始与结束日期的方法
Jun 22 PHP
PHP将整数数字转换为罗马数字实例分享
Mar 17 PHP
PHP网页缓存技术优点及代码实例
Jul 29 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的几个常用加密函数
2016/02/03 PHP
PHP连接MySQL进行增、删、改、查操作
2017/02/19 PHP
laravel-admin 管理平台获取当前登陆用户信息的例子
2019/10/08 PHP
window.open的功能全解析
2006/10/10 Javascript
自制轻量级仿jQuery.boxy对话框插件代码
2010/10/26 Javascript
jQuery中.live()方法的用法深入解析
2013/12/30 Javascript
js实现二代身份证号码验证详解
2014/11/20 Javascript
JS刷新父窗口的几种方式小结(推荐)
2016/11/09 Javascript
Vue.JS入门教程之自定义指令
2016/12/08 Javascript
解决Window10系统下Node安装报错的问题分析
2016/12/13 Javascript
js基于FileSaver.js 浏览器导出Excel文件的示例
2017/08/15 Javascript
Vue Cli与BootStrap结合实现表格分页功能
2017/08/18 Javascript
利用JQuery操作iframe父页面、子页面的元素和方法汇总
2017/09/10 jQuery
canvas轨迹回放功能实现
2017/12/20 Javascript
JS运动特效之任意值添加运动的方法分析
2018/01/24 Javascript
JS使用Date对象实时显示当前系统时间简单示例
2018/08/23 Javascript
React如何实现浏览器打印部分内容详析
2019/05/19 Javascript
Javascript地址引用代码实例解析
2020/02/25 Javascript
javascript实现获取中文汉字拼音首字母
2020/05/19 Javascript
js实现从右往左匀速显示图片(无缝轮播)
2020/06/29 Javascript
python生成日历实例解析
2014/08/21 Python
Python如何获取系统iops示例代码
2016/09/06 Python
python实现textrank关键词提取
2018/06/22 Python
Python操作rabbitMQ的示例代码
2019/03/19 Python
python中with用法讲解
2020/02/07 Python
html5配合css3实现带提示文字的输入框(摆脱js)
2013/03/08 HTML / CSS
HTML5添加鼠标悬浮音响效果不使用FLASH
2014/04/23 HTML / CSS
在HTML5 Canvas中放入图片和保存为图片的方法
2014/05/03 HTML / CSS
巴西宠物商店:Cobasi
2019/04/19 全球购物
我的大学生活职业生涯规划
2014/01/02 职场文书
学校光盘行动倡议书
2015/04/28 职场文书
学校教学工作总结2015
2015/05/19 职场文书
钱学森观后感
2015/06/04 职场文书
贷款担保书范本
2015/09/22 职场文书
Python常遇到的错误和异常
2021/11/02 Python
vue3使用vuedraggable实现拖拽功能
2022/04/06 Vue.js