100字范文,内容丰富有趣,生活中的好帮手!
100字范文 > php自定义错误日志是什么?错误日志实例代码详解

php自定义错误日志是什么?错误日志实例代码详解

时间:2022-09-20 17:58:46

相关推荐

php自定义错误日志是什么?错误日志实例代码详解

后端开发|php教程

自定义,php,是什么

后端开发-php教程

仿源码之家网站,vscode打开文件慢,ubuntu录制bug,tomcat是否卸载,sqlite3封装,爬虫心得体会感受50字,ajax表单验证php,白云seo优化推广公司,.net网站,简易网页编辑器,微信高级模板下载lzw

项目中需要对定义错误日志及时处理, 那么就需要修改自定义错误日志的输出方式(写日志、发邮件、发短信)

驱动读写模块源码,vscode报404,多硬盘的情况下安装ubuntu,linux杀掉tomcat,sqlite脚本文件,bootstrap级联插件,前端开发用的什么框架,室内放什么防爬虫,php mysql 过程,沈阳筑巢seo,动漫类网站模版,如何制作静态网页,微擎微信模板消息lzw

一. register_shutdown_function(array(‘phperror’,’shutdown_function’)); //定义PHP程序执行完成后执行的函数

opencv 模板匹配源码,安卓 写代码 vscode,ubuntu df du,查看是否tomcat,蟑螂和爬虫,php word在线阅读,盐城seo推广公司有哪些,区分官方门户网站和商业门户网站,苹果10免费模板下载lzw

函数可实现当程序执行完成后执行的函数,其功能为可实现程序执行完成的后续操作。程序在运行的时候可能存在执行超时,或强制关闭等情况,但这种情况下默认的提示是非常不友好的,如果使用register_shutdown_function()函数捕获异常,就能提供更加友好的错误展示方式,同时可以实现一些功能的后续操作,如执行完成后的临时数据清理,包括临时文件等。

可以这样理解调用条件:

1、当页面被用户强制停止时

2、当程序代码运行超时时

3、当PHP代码执行完成时,代码执行存在异常和错误、警告

二. set_error_handler(array(‘phperror’,’error_handler’)); // 设置一个用户定义的错误处理函数

通过 set_error_handler() 函数设置用户自定义的错误处理程序,然后触发错误(通过 trigger_error()):

三. set_exception_handler(array(‘phperror’,’appException’)); //自定义异常处理

在写日志前,我们问问自己:为什么我们有时要记录自定义的日志呢?而不用系统默认的日志记录方式呢?

1.团队需要一个统一格式的日志方便管理

2.大量无用错误日志占据硬盘空间,仅需记录有意义的日志。

那么,实践一下。

1.打开你的php.ini

2.打开日志记录,将

log_errors = Off

改成

log_errors = On

3.将php.ini保存退出并重启web服务器

4.在你的代码最前面加上如下代码

<?php//错误处理函数function myErrorHandler($errno, $errstr, $errfile, $errline){ $log_file = "./php_%s_log_".date("Ymd").".log";//定义日志文件存放目录和文件名 $template = \; switch ($errno) { case E_USER_ERROR: $template .= "用户ERROR级错误,必须修复 错误编号[$errno] $errstr "; $template .= "错误位置 文件$errfile,第 $errline 行\n"; $log_file = sprintf($log_file,error); exit(1);//系统退出 break; case E_USER_WARNING: $template .= "用户WARNING级错误,建议修复 错误编号[$errno] $errstr "; $template .= "错误位置 文件$errfile,第 $errline 行\n"; $log_file = sprintf($log_file,warning); break; case E_USER_NOTICE: $template .= "用户NOTICE级错误,不影响系统,可不修复 错误编号[$errno] $errstr "; $template .= "错误位置 文件$errfile,第 $errline 行\n"; $log_file = sprintf($log_file, otice); break; default: $template .= "未知错误类型: 错误编号[$errno] $errstr "; $template .= "错误位置 文件$errfile,第 $errline 行\n"; $log_file = sprintf($log_file,unknown); break; } file_put_contents($log_file,$template,FILE_APPEND); return true;}$error_handler = set_error_handler("myErrorHandler");//开启自定义错误日志

5.试着在刚才的代码后写下一段错误代码

echo 1/0;

看看你定义的路径下是否多了一个日志文件呢?:)

注:以下级别的错误不能由用户定义的函数来处理: E_ERROR、 E_PARSE、 E_CORE_ERROR、 E_CORE_WARNING、 E_COMPILE_ERROR、 E_COMPILE_WARNING,和在 调用 set_error_handler() 函数所在文件中产生的大多数 E_STRICT。

不过当你开启了错误日志系统(php.ini中的log_error = on)并且指定了系统日志文件(同样也是php.ini中的error_log=路径名),并且error_reporting开启了全部后,以上的错误都会作为系统错误日志而记录在你定义的文件中。

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。