thinksnsv4.6运行php,ThinkSNS开启调试模式

首先说下开启调试模式完整操作。

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

如果没有做第三步操作,你可能需要去频繁的清除缓存。因为我们开发的时候我们是肯定不希望模版是被缓存的,因为变动很大嘛,我之前的解决办法是,在入口执行了一次清除缓存

pclose(popen('php '.__DIR__.'/cleancache.php','r'));

其实呢,这样做之后发现,模版目录_runtime已经被清空了,但是还是不是自己最新修改的内容。这是因为ThinkSNS的调试除了ThinkPHP自带的调试外,在模版编译这块使用的是自己的调试标识变量($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);

}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值