【记录错误(生产环境)】

php.ini:

① 开启 / 关闭 错误日志功能

log_errors = On

② 设置 log_errors 的最大字节数

log_errors_max_len = 

其他:

选项 描述
log_errors 设置是否将错误信息记录到日志或者 error_log 中
error_log   设置脚本错误将记录到的文件
log_errors_max_len 设置 log_errors 的最大字节数
ignore_repeated_errors 是否忽略重复的错误信息
ignore_repeated_source 是否忽略重复错误消息的来源
track_errors 如果开启此选项,最后一个错误将永久保存在$php_errormsg 中

【方法一】将错误记录到指定的文件中 

① 开启 php.ini 中的 log_errors

② 指定 错误日志的保存路径,例如:

error_log = "d:/wamp/logs/php_error.log"

【例1】

<?php
//关闭错误显示
ini_set('display_errors', );
//显示所有错误
error_reporting(-); //记录错误
//通知级别的错误
echo $test;
//警告
settype($var, 'dee');
//致命错误
test();

页面不会有任何输出。打开 D:\wamp\logs\php_error.log:

[-May- :: UTC] PHP Notice:  Undefined variable: test in D:\practise\php\Error\error1.php on line 

[-May- :: UTC] PHP Stack trace:

[-May- :: UTC] PHP   . {main}() D:\practise\php\Error\error1.php:

[-May- :: UTC] PHP Warning:  settype() [<a href='function.settype'>function.settype</a>]: Invalid type in D:\practise\php\Error\error1.php on line 

[-May- :: UTC] PHP Stack trace:

[-May- :: UTC] PHP   . {main}() D:\practise\php\Error\error1.php:

[-May- :: UTC] PHP   . settype() D:\practise\php\Error\error1.php:

[-May- :: UTC] PHP Fatal error:  Call to undefined function test() in D:\practise\php\Error\error1.php on line 

[-May- :: UTC] PHP Stack trace:

[-May- :: UTC] PHP   . {main}() D:\practise\php\Error\error1.php:

【例2】在 ini_set() 中设置保存错误日志的路径。

<?php
//关闭错误显示
ini_set('display_errors', 0);
//设置错误日志的路径
ini_set('error_log', 'D:\wamp\logs\php_error_2.log');
//显示所有错误
error_reporting(-1); //记录错误
//通知级别的错误
echo $test;
//警告
settype($var, 'dee');
//致命错误
test();

页面不会有任何输出。打开 D:\wamp\logs\php_error_2.log:

[19-May-2015 16:04:41 UTC] PHP Notice:  Undefined variable: test in D:\practise\php\Error\error1.php on line 11

[19-May-2015 16:04:41 UTC] PHP Stack trace:

[19-May-2015 16:04:41 UTC] PHP   1. {main}() D:\practise\php\Error\error1.php:0

[19-May-2015 16:04:41 UTC] PHP Warning:  settype() [<a href='function.settype'>function.settype</a>]: Invalid type in D:\practise\php\Error\error1.php on line 13

[19-May-2015 16:04:41 UTC] PHP Stack trace:

[19-May-2015 16:04:41 UTC] PHP   1. {main}() D:\practise\php\Error\error1.php:0

[19-May-2015 16:04:41 UTC] PHP   2. settype() D:\practise\php\Error\error1.php:13

[19-May-2015 16:04:41 UTC] PHP Fatal error:  Call to undefined function test() in D:\practise\php\Error\error1.php on line 15

[19-May-2015 16:04:41 UTC] PHP Stack trace:

[19-May-2015 16:04:41 UTC] PHP   1. {main}() D:\practise\php\Error\error1.php:0

【例3】记录什么时候用户尝试以什么密码来登录系统的时间和 ip 地址(例如通过日志分析注水机器人)

login.html

<!DOCTYPE html>
<html>
<head>
<title>TODO supply a title</title>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
</head>
<body>
<h1>登录</h1>
<form action="doAction.php" method="post">
用户名:<input type="text" name="username" /><br />
密码:<input type="password" name="password" /><br />
<input type="submit" value="登录">
</form>
</body>
</html>

doAction.php:

<?php
//不显示所有错误
ini_set('display_errors', 0);
//错误等级:所有错误
error_reporting(-1);
//开启错误日志功能
ini_set('log_errors', 'on');
//设置错误日志保存路径
ini_set('error_log', 'D:\wamp\logs\login.log');
//忽略重复的错误信息
ini_set('ignore_repeated_errors', 'on');
//忽略重复消息的来源
ini_set('ignore_repeated_source', 'on'); //设置时区
ini_set('date.timezone', 'PRC'); $username = $_POST['username'];
$password = $_POST['password']; if($username == 'admin' && $password == 'admin'){
echo '登录陈功';
}else{
//记录什么时候管理员尝试以什么密码来登录系统的时间和ip地址
$date = date("Y-m-d H:i:s", time());
$ip = $_SERVER['REMOTE_ADDR'];
$message = "用户{$username}在{$date}以{$password}尝试登录系统,当前用户的ip地址为{$ip}";
error_log($message);
//跳转
header('location:login.html');
}

打开:D:\wamp\logs\login.log:

[19-May-2015 16:25:59 UTC] 用户dee在2015-05-20 00:25:59以dee尝试登录系统,当前用户的ip地址为127.0.0.1

【方法二】将错误记录到系统日志中

【方法三】将错误以邮件形式发送

PHP 错误与异常 笔记与总结(5)配置文件中与错误日志相关的选项 && 将错误记录到指定的文件中的更多相关文章

  1. PHP 错误与异常 笔记与总结(10)错误处理器测试

    关联文件:myErrorHandler.php (上一篇) 先测试通知级别的错误的自定义处理: testErrorHandler.php <?php require_once 'myErrorH ...

  2. PHP 错误与异常 笔记与总结(15 )使用观察者模式处理异常信息

    使异常处理变得更灵活.可观察,可以使用设计模式中的观察者模式. 文件 ① 定义观察者的接口 ExceptionObserver.php: <?php /* 给观察者定义的规范 */ interf ...

  3. PHP 错误与异常 笔记与总结(14 )记录和发送异常信息

    当发生异常时,把异常信息记录到日志文件中: <?php header('content-type:text/html; charset=utf-8'); class LogException e ...

  4. PHP 错误与异常 笔记与总结(8)自定义错误处理函数 set_error_handler()

    通过 Set_error_handler() 函数设置用户自定义的错误处理函数. 步骤: ① 创建错误处理函数 ② 设置不同级别调用函数 ③ Set_error_handler() 函数制定接管错误处 ...

  5. PHP 错误与异常 笔记与总结(3)PHP 配置文件(php.ini)中与错误相关的选项 与 设置错误级别

    [PHP 配置文件中与错误相关的选项 ] 选项 描述 error_reporting 设置错误报告的级别 display_errors 是否显示错误 log_errors 设置是否将错误信息记录到日志 ...

  6. PHP 错误与异常 笔记与总结(12 )异常

    ① 异常的概念:异常和错误的区别 PHP 部分借鉴了 C++ 和 JAVA 中的异常处理机制.PHP 中的异常是指 程序运行和预期不太一致,与错误是两个不同的概念. ② 异常的语法结构 [例1] &l ...

  7. PHP 错误与异常 笔记与总结(18 )页面重定向实现

    在发生错误时,将用户重定向到另一个页面. <?php header('content-type:text/html; charset=utf-8'); class ExceptionRedire ...

  8. PHP 错误与异常 笔记与总结(17 )像处理异常一样处理 PHP 错误

    有两种方式可以在 PHP 中以异常的方式处理错误: ① PHP 内置的 ErrorException类(也是 Exception 类的子类) <?php function exception_e ...

  9. PHP 错误与异常 笔记与总结(4)通过 trigger_error 触发 PHP 错误

    [错误抑制符@] 除了 php.ini 中 error_reporting 和 display_errors 的设置.error_reporting() 函数.ini_set() 函数 外,还可以使用 ...

随机推荐

  1. Android配置----DDMS 连接真机(己ROOT),用file explore看不到data/data文件夹的解决办法

    Android DDMS 连接真机(己ROOT),用file explore看不到data/data文件夹,问题在于data文件夹没有权限,用360手机助手或豌豆荚也是看不见的. 有以下两种解决方法: ...

  2. mysql中char,varchar,text区别总结

    具体对这三种类型的说明不做阐述可以查看mysql帮助文档. char的总结:      char最大长度是255字符,注意是字符数和字符集没关系.可以有默认值,尾部有空格会被截断.varchar的总结 ...

  3. EF架构~为EF DbContext生成的实体添加注释(T5模板应用)(转载)

    转载地址:http://www.newlifex.com/showtopic-1072.aspx 最近新项目要用Entity Framework 6.x,但是我发现从数据库生成模型时没有生成字段的注释 ...

  4. hrbustoj 1073:病毒(并查集,入门题)

    病毒Time Limit: 1000 MS Memory Limit: 65536 KTotal Submit: 719(185 users) Total Accepted: 247(163 user ...

  5. ORA-00824:cannot set SGA_TARGET or MEMORY_TARGET due to existing internal settings

    练习时执行一条修改数据库连接数的语句: alter system set processes=1 scope=spfile; 然后关闭数据库: shutdown 再启动数据库时,出现异常,报错信息如下 ...

  6. Z.XML第二次迭代分数分配

    这是一篇简介的日志. 它关于二轮迭代Z-XML团队7名成员的分数分配. 每名成员的工作内容与之前的任务分工相同,即,大家都非常好的完成了计划的工作. 按照最初设定的分数分配原则,在今晚大家吃全家桶之前 ...

  7. SQL Server 2000 ——系统表和系统视图

    一.系统表 数据字典的详细信息请查SQL SERVER BOL,这里仅列出一部分. 1.1.sysservers 1.查看所有本地服务器及链接服务器 select * from master..sys ...

  8. hadoop1.2.1的namenode格式化失败的问题

    最近要开始找工作,就在原来搭建好的hadoop1.2.1的伪分布式跑跑mapreduce 很久没用,就想着格式化一下namode,结果: Format aborted in /uar/local/ha ...

  9. 关于sqoop与datax。 和sqoop to oracle插件OraOop

         之前我还在想了解下datax,是否有可能替换sqoop,但了解后发现,datax和sqoop的业务场景是不同的.前者适合异构数据库的同步,后者适合hdfs与rdbms互相之间的同步.针对sq ...

  10. Objective-C专题,是学习iOS开发的前奏(转)

    第一个OC的类 来源:http://www.cnblogs.com/mjios/archive/2013/04/06/3002814.html 本文目录 一.语法简介 二.用Xcode创建第一个OC的 ...