thinksnsv4.6运行php,ThinkSNS开启调试模式
首先說下開啟調(diào)試模式完整操作。
1、\config\config.inc.php配置文件中增加兩個鍵值對
'APP_DEBUG' => true,
'SHOW_PAGE_TRACE' => true,
2、把index.php里面的報錯給開啟
ini_set('display_errors',true);
error_reporting(E_ALL);
set_time_limit(0);
3、把\core\core.php里的$ts['_debug']改為true
如果沒有做第三步操作,你可能需要去頻繁的清除緩存。因為我們開發(fā)的時候我們是肯定不希望模版是被緩存的,因為變動很大嘛,我之前的解決辦法是,在入口執(zhí)行了一次清除緩存
pclose(popen('php '.__DIR__.'/cleancache.php','r'));
其實呢,這樣做之后發(fā)現(xiàn),模版目錄_runtime已經(jīng)被清空了,但是還是不是自己最新修改的內(nèi)容。這是因為ThinkSNS的調(diào)試除了ThinkPHP自帶的調(diào)試外,在模版編譯這塊使用的是自己的調(diào)試標識變量($ts['_debug'])。
看下$ts['_debug']在下面兩處使用到了
# 第一處 \core\core.php
//載入核心運行時文件
if(file_exists(CORE_PATH.'/'.CORE_MODE.'Runtime.php') && !$ts['_debug']){
include CORE_PATH.'/'.CORE_MODE.'Runtime.php';
}else{
include CORE_LIB_PATH.'/'.CORE_MODE.'.php';
}
# 第二處 \core\OpenSociax\functions.inc.php
function fetch(...){
if(!$ts['_debug'] && file_exists($templateCacheFile)) {
extract($tvar, EXTR_OVERWRITE);
//載入模版緩存文件
include $templateCacheFile;
//重新編譯
}else{
tshook('tpl_compile',array('templateFile',$templateFile));
// 緩存無效 重新編譯
tsload(CORE_LIB_PATH.'/Template.class.php');
tsload(CORE_LIB_PATH.'/TagLib.class.php');
tsload(CORE_LIB_PATH.'/TagLib/TagLibCx.class.php');
$tpl = Template::getInstance();
// 編譯并加載模板文件
$tpl->load($templateFile,$tvar,$charset);
}
}
總結(jié)
以上是生活随笔為你收集整理的thinksnsv4.6运行php,ThinkSNS开启调试模式的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 程序化广告系统架构
- 下一篇: java饲养员喂动物_体现JAVA中的面