3.0版本的调试模式开启,必须在项目入口文件中添加常量APP_DEBUG定义,如下:
  1. define('APP_DEBUG',True); // 开启调试模式

开启调试模式后,你可能感觉不到什么变化,不管你信不信,调试模式已经开启了。
因为,新版的调试模式并没有默认开启页面Trace(这个功能在之前的版本是伴随着调试模式自动开启的),现在页面Trace功能是单独设置的,哪怕你在部署模式下也可以单独开启页面Trace信息显示。总之,当你需要页面Trace信息功能的时候,手动配置开启,例如:

  1. 'SHOW_PAGE_TRACE'=>True,

它与是否开启调试模式无关。
那么,新版的调试模式到底有什么特点呢?我们来慢慢揭晓吧~

调试配置

说到调试模式,首先需要了解如何进行调试配置。虽然默认的调试配置文件已经可以满足大多数情况的需求。
如果你开启了调试模式,系统会首先加载系统默认的调试配置文件,位于ThinkPHP/Conf/debug.php,如果你没有定义项目的调试配置文件的话,调试模式的参数就可以参考系统调试配置文件中的设置。默认调试配置参数如下:

  1. return  array(
  2. 'LOG_RECORD'=>true,  // 进行日志记录
  3. 'LOG_EXCEPTION_RECORD'  => true,    // 是否记录异常信息日志
  4. 'LOG_LEVEL'       =>   'EMERG,ALERT,CRIT,ERR,WARN,NOTIC,INFO,DEBUG,SQL',  // 允许记录的日志级别
  5. 'DB_FIELDS_CACHE'=> false, // 字段缓存信息
  6. 'APP_FILE_CASE'  =>   true, // 是否检查文件的大小写 对Windows平台有效
  7. 'TMPL_CACHE_ON'    => false,        // 是否开启模板编译缓存,设为false则每次都会重新编译
  8. 'TMPL_STRIP_SPACE'      => false,       // 是否去除模板文件里面的html空格与换行
  9. 'SHOW_ERROR_MSG'        => true,    // 显示错误信息
  10. );

系统调试配置中设置了:

  • 开启日志记录,任何错误信息和调试信息都会详细记录,便于调试;
  • 关闭模板缓存,模板修改可以即时生效;
  • 记录SQL日志,方便分析SQL;
  • 关闭字段缓存,数据表字段修改不受缓存影响;
  • 开启文件大小写严格检查(即使是Windows平台),帮助你提前发现Linux部署问题;

调试模式的目的就是为了更加方便的发现、记录、分析和解决错误,而在部署模式下面,可能很多潜在的错误你根本发现不了,这些错误就像一颗定时炸弹,存在隐患。
如果你觉得系统默认的调试配置不能满足你的需求,例如你想开启页面Trace信息显示的话,可以增加项目的调试配置文件,例如:

  1. return array(
  2. 'SHOW_PAGE_TRACE'  => True, // 显示页面Trace信息
  3. );

项目调试配置文件中只需要添加和系统调试配置文件不同(增加或者修改)的参数,然后保存到项目的Conf/debug.php即可。
一旦项目关闭调试模式,调试配置文件(包括系统调试配置文件和项目调试配置文件)就会失效,所有在调试配置文件中的参数将不会再起作用。同时,这个时候,系统又会按照惯例配置文件和项目配置文件中的参数配置来运行,因此你要懂得如何区别使用项目配置文件和项目调试配置文件。

调试状态

应用调试状态是新版新提出的一个概念,作用是在开启调试模式的状态下,可以给项目设置不同的应用状态,并自动加载不同的项目配置文件。可以当成是项目开发过程中的几个阶段,尤其是这些阶段需要同时或者交叉运行的时候,例如开发小组希望有自己的调试数据库和调试信息,而测试小组又希望有一个干净的测试环境,你不希望总是在更改项目配置文件或者调试配置文件。那么就可以为不同的阶段设置不同应用调试状态,并单独定义不同的配置文件。
应用调试状态的更改是通过设置APP_STATUS参数,默认的参数设置是debug,如果想在调试模式下面增加应用状态,例如测试状态,则可以在项目配置文件中改变设置如下:

  1. 'APP_STATUS' => 'test', //应用调试模式状态

这样的话,系统会自动尝试加载项目配置目录下面的test.php 配置文件,可以在test配置文件中改变相关设置,例如改变测试数据库的连接信息等等。

总结

通常情况下,调试配置文件里面可以进行一些开发阶段或者测试所需要的配置。例如,配置额外的数据库连接用于调试,开启日志写入便于查找错误信息、开启页面Trace输出更多的调试信息等等,所有这些,一旦关闭调试模式,都会失效。
由于调试模式没有任何缓存,因此涉及到较多的文件IO操作和模板实时编译,所以在开启调试模式的情况下,性能会有一定的下降,但不会影响部署模式的性能。

Thinkphp开启调试模式的更多相关文章

  1. 解决ThinkPHP中开启调试模式无法加载模块的问题。

    刚开始学习ThinkPHP就遇到这种问题,还是自己粗心. 错误如下: 原因:开启调试模式,区分大小写的,要把模块名首字母大写就OK了.也就是: [plain] view plain copy http ...

  2. 如何在ThinkPHP中开启调试模式

    1.为什么使用调试模式? 因为调试会在我们的模板页的最后增加一些trace信息. 2.什么是trace信息? 是ThinkPHP为我们提供好的一些包含了系统运行时间.占用内存.加载时间.请求的协议.. ...

  3. 解决ThinkPHP关闭调试模式时报错的问题汇总

    解决ThinkPHP关闭调试模式时报错的问题汇总 案例一: 最近用ThinkPHP开发一个项目,本地开发测试完成上传到服务器后,第一次打开正常,再刷新页面时就出现 "页面调试错误,无法找开页 ...

  4. thinkphp关闭调试模式(APP_DEBUG => false),导致程序出错

    thinkphp关闭调试模式(APP_DEBUG => false),导致程序出错,开启调试模式,不报错,怎么解决? 查看Logs日志记录: [ --29T09::+: ] 113.108.11 ...

  5. linux下thinkphp取消调试模式后找不到网页解决方案

    1.最大嫌疑是Runtime目录权限不足,导致common~runtime.php文件无法生成, 解决:1.整个Runtime目录删除,让系统重新生成; 2.给Runtime及以下的所有文件足够权限0 ...

  6. android user版本默认开启调试模式

    由于项目需要,需要发布版本默认开启调试模式,修改方式如下: 1.开启开发者模式 context.getSharedPreferences(DevelopmentSettings.PREF_FILE,C ...

  7. [其他]Jboss容器开启调试模式

    1.登陆服务器: 2.找到$JBOSS_HOME/bin/run.conf 3.找到# Sample JPDA settings for remote socket debuging这项,并将说明下方 ...

  8. 小米note开启调试模式

    1.刷机为开发版本. 2.拨电话界面输入   *#*#717717#*#*  开启调试模式. 3.驱动好像会自己安装.

  9. mac 蓝牙开启调试模式

    mac 蓝牙开启调试模式 按住shift+option+鼠标右键点右上角的蓝牙图标

随机推荐

  1. Powershell 远程连接ARM Windows Server VM 并关闭 Firewall

    准备环境:Azure ARM Windows Server 2008 R2 机器 1.登陆机器查看防火墙,是开着的 2.查看机器的监听端口,发现没有Powershell远程管理对应的端口5985或59 ...

  2. Oracle的窗口和自动任务

    Oracle数据库自己会例行做一些定时任务,比如会自动进行统计信息收集等作业任务.如果统计信息收集的时间正好赶上业务的高峰期,那就有可能由此引发一系列性能故障. 那么,我们该如何查看这些数据库自动去做 ...

  3. 2778:Ride to School-poj

    2778:Ride to School 总时间限制:  1000ms 内存限制:  65536kB 描述 Many graduate students of Peking University are ...

  4. 用swoole和websocket开发简单聊天室

    首先,我想说下写代码的一些习惯,第一,任何可配置的参数或变量都要写到一个config文件中.第二,代码中一定要有日志记录和完善的报错并记录报错.言归正传,swoole应该是每个phper必须要了解的, ...

  5. WPF自定义产品框架

    在讲解之前先看一下效果,有助于理解: 这是客户端的效果图.整个产品分为两部分:1.WPF开发的展示效果的客户端   2.WCF开发的提供数据服务接口的服务端   本章主要讲解一下实际中开发WPF开发客 ...

  6. php提供的对称加密算法

    KEY 是之前定义的常量 Mcrypt::encrypt(); Mcrypt::decrypt(); defined('ROOT') or exit('Access Denied'); class M ...

  7. UWP 调用outlook邮箱反馈

    public static async Task FeedbackAsync(string address, string subject, string body) { if (address == ...

  8. Ext.chart.Chart 显示图标 -- 本地数据

    先来张直观的图,基于ext4.2制作 这就是弹出来的图表了. 今天先搭建一个本地数据版,也是静态数据版. 点击一个按钮执行一个function,来看function里面的东西: 一.依赖 Ext.re ...

  9. 机房收费系统——转换list泛型时,字段名称不正确应出现故障

    因为之前对泛型研究了一番,所以就開始尝试着在机房收费系统重构中增加了泛型的使用. 可是到了做学生查看剩余金额这个功能的时候,还是依照之前的方法做的,可是在载入数据的时候班级这个框就没有显示出来--然后 ...

  10. 自己定义View Controller转换动画

    原文链接 : Introduction to Custom View Controller Transitions and Animations 原文作者 : joyce echessa 译文出自 : ...