• 技术文章 >后端开发 >PHP问题

    php怎么将错误日志写入文件

    青灯夜游青灯夜游2021-09-02 19:29:33原创141

    php将错误日志写入文件的方法:1、在配置文件php.ini中,搜索“error_log”项,配置日志文件的路径;2、利用error_log()函数将错误日志写入配置好的日志文件中,语法“error_log(需要记录的错误信息,0);”。

    本教程操作环境:windows7系统、PHP7.1版,DELL G3电脑

    如果想使用自己指定的文件记录错误日志,一定要确保这个文件存放在文档根目录之外,以减少遭到攻击的可能。并且该文件一定要让 PHP 脚本具有写权限。假设在 Linux 操作系统中,将 /usr/local/ 目录下的 error.log 文件作为错误日志文件,并设置 Web 服务器进程用户具有写的权限。然后在 PHP 的配置文件中,将 error_log 指令的值设置为这个错误日志文件的绝对路径。

    需要将 php.ini 中的配置指令做如下修改:

    error_reporting  =  E_ALL                             // 将会向PHP报告发生的每个错误  
    display_errors = Off                                     // 不显示满足上条 指令所定义规则的所有错误报告  
    log_errors = On                                           // 决定日志语句记录的位置  
    log_errors_max_len = 1024                         // 设置每个日志项的最大长度  
    error_log = E:/php_log/php_error.log         // 指定产生的错误报告写入的日志文件位置

    PHP 的配置文件按上面的方式设置完成以后,并重新启动 Web 服务器。这样,在执行 PHP 的任何脚本文件时,产生的所有错误报告都不会在浏览器中显示,而会记录在自己指定的错误日志 E:/php_log/php_error.log 中。

    此外,不仅可以记录满足 error_reporting 所定义规则的所有错误,而且还可以使用 PHP 中的 error_log() 函数把错误信息发送到 web 服务器的错误日志或者到一个文件里。

    error_log() 函数的原型如下所示:

    error_log ( string $message [, int $message_type = 0 [, string $destination [, string $extra_headers ]]] ) : bool

    参数说明如下:

    【示例】以登入 Mysql 数据库为例,当登入失败时记录错误信息。

    <?php
        $link = mysqli_connect("127.0.0.1", "my_user", "my_password", "my_db");
        if (!$link) {
            error_log('Mysql 数据库连接失败!',0);
            exit();
        }
    ?>

    运行上面的代码,会在 php.ini 配置文件中 error_log 一项所设置的目录中生成对应的错误日志文件,文件内容如下:

    [08-May-2020 13:17:31 PRC] PHP Warning:  mysqli_connect(): (HY000/1045): Access denied for user 'my_user'@'localhost' (using password: YES) in D:\WWW\index.php on line 2
    [08-May-2020 13:17:31 PRC] Mysql 数据库连接失败!

    推荐学习:《PHP视频教程

    以上就是php怎么将错误日志写入文件的详细内容,更多请关注php中文网其它相关文章!

    声明:本文原创发布php中文网,转载请注明出处,感谢您的尊重!如有疑问,请联系admin@php.cn处理
    专题推荐:php 错误日志
    上一篇:php ini_set 不起作用怎么办 下一篇:php end方法是干什么的
    线上培训班

    相关文章推荐

    • php怎么替换某一行内容• php怎么删除mysql行• expose_php不起作用怎么办• thinkphp5与laravel的区别是什么• php ini_set 不起作用怎么办

    全部评论我要评论

  • 取消发布评论发送
  • 1/1

    PHP中文网