码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • php基础学习之错误处理(其二)


    在实际应用中,开发者当然不希望把自己开发的程序的错误暴露给用户,一方面会动摇客户对己方的信心,另一方面容易被攻击者抓住漏洞实施攻击,同时开发者本身需要及时收集错误,因此需要合理的设置错误显示与记录错误日志


    一,错误显示设置

    错误显示设置用于设置哪些错误该显示,以及该如何显示

    在php中,其实有两种方式来设置当前脚本的错误处理方式

    (一)php配置文件

    在php.ini文件基于全局的配置,该文件下有两个参数

    分别是error_reporting和display_errors,前者用于设置显示什么级别的错误,后者用于设置是否显示错误

    (注:该知识点对网安SQL注入有意义,此处不细讲)

    (二)php脚本中设置

    error_reporting()

    该函数可以在php脚本中调用,以设置错误的显示级别,需要传入一个错误代号(常量),见本篇【三】->php基础学习之错误处理(其一)-CSDN博客

    例如传入0时,将不显示任何错误信息

    当调用error_reporting()函数不传入参数时也是符合语法的,此时它将返回当前php脚本设置的错误级别

    如下图所示:在上一篇【三.(六)】已经验证过各错误代号(常量)的具体值,其中E_ALL的值是32767对应的二进制数,E_NOTICE的值是8对应的二进制数,那么表达式【E_ALL & ~E_NOTICE】(该表达式的含义是除去NOTICE级别的错误)的结果正好是下面脚本的输出结果32759,说明error_reporting()函数返回的错误级别是正确的->php基础学习之错误处理(其一)-CSDN博客

    ini_set()

    和【一.(一)】本质是一样的,通过修改配置文件中的参数进行设置,但是脚本中的设置优先级比配置文件中的优先级更高(如果配置文件和脚本文件中的配置项不一致,以脚本中的配置优先),当然前提是脚本中的相关代码被执行

    该函数有两个参数,第一个参数传入一个字符串(这个字符串就是配置项的名称),第二个参数传入该配置项对应的值

    例如在上文提到的error_reporting,使用ini_set()函数设置显示


    二,错误日志设置

    在生产环境中无可避免会发生错误,但作为开发者又不希望展示给用户看,所以需要使用日志记录错误以便做出相应debug

    参考本篇->如何配置使用php.ini中的错误日志功能? (newsn.net)

    (一)开启日志功能

    php日志功能的开关由参数【log_errors】决定,找到它并赋值为On

    (二)指定路径

    错误日志设置需要定义好error_log配置参数,并赋予该配置参数一个值(此值是一个.log文件的路径<注意路径的格式,一般用左斜杠>,将会保存程序测试或使用时发生的错误,如果需要关闭记录日志的功能,直接将此参数以及值注释或者删除即可)

    (三)测试

    (实际开发中一般将【display_errors】或【display_startup_errors】等参数设置为Off,这样在网页中就不会显示错误而是只将错误记录到日志文件中)

  • 相关阅读:
    我用Coze给自己的服务号加了一个多功能的GPT服务机器人
    2022-07-19 达梦数据库 连接实例、执行脚本、系统命令
    mysql索引失效的几种情况
    猿创征文|JVM之图解垃圾收集器2-Shenandoah和ZGC
    linux 上安装tomcat ,并将tomcat注册为服务
    【论文阅读 05】图像异常检测研究现状综述
    mysql为什么使用B+树
    8款提高小团队协作效率的app软件,你用过几款?
    覆盖5大任务,30+特色模型,高性能、全流程开发套件PaddleRS助力遥感影像智能解译化繁为简...
    搭建个人博客,Docsify+Github webhook+JGit解决方案
  • 原文地址:https://blog.csdn.net/liKeQing1027520/article/details/136332246
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号