ThinkPHP报Class 'Core\Log' not found竟然是由这个原因导致的
项目在开发阶段运行的好好的(Debug=true),上线后(Debug=false)其中有一个页面报“对不起,您的页面暂进无法找到!”错误。摸不清头脑,看看了这个页面也没有什么两样,可就是提示这句话,也不知道是哪一步报错了。最后用代码中用全文检索搜索这句话发现:
\ThinkPHP\Conf\convention.php
/* 错误设置 */
'ERROR_MESSAGE' => '对不起,您的页面暂进无法找到!',//错误显示信息,非调试模式有效
'ERROR_PAGE' => '', // 错误定向页面
'SHOW_ERROR_MSG' => false, // 显示错误信息
'TRACE_MAX_RECORD' => 100, // 每个级别的错误信息 最大记录数
由此可见出现此提示是因为这里配置了出错后的提示语,再看到后面的一个配置 'SHOW_ERROR_MSG' => false, // 显示错误信息 这里已配置不显示错误信息,也就是说出任何错误都会提示"ERROR_MESSAGE"配置的内容,因此我们给配置为'SHOW_ERROR_MSG' => true,然后删除runtime里面的内容,再刷新页面,果然看到了错误提示:
Class 'Core\Log' not found
这个错误更麻烦,找了半天,首先出错页面没有引用Core\Log,唯独只有这一个页面报错,还是摸不清头脑。最头痛的是,一量把Debug=false或SHOW_PAGE_TRACE=true开启页面调试就不会有此错误,在网上也找不到类似的资料。没办法,一句代码一句代码的扣:
首先将出错页面的代码全部删除,只留一个Action,访问此Action成功!
接着再把代码全部恢复访问此Action失败!
目测其中有一个Action有问题,然后仔细查阅了一下代码,跟其它页面对比对比,找出最有可能出错的一个方法,把这个方法注释掉,再测试,访问成功!
再恢复方法中的部分代码再测试,访问失败!就这样来回测试,最后定位到其中的一句代码:
$_result_txt.= self::updateOrderExcel($_child[0], $_child[1], $_child[2],&$users,&$vars);
这句代码只要存在就报错。但这句代码根本就没执行,再细找最后发现:&$users,&$vars 这2个变量,如果把 & 去掉就好了。加上就不行。猜测的原因可能是这里代码解析出错了,然后调用写日志又失败了。结果就报这个错。
这里写 & 符号是因为我要传递变量的引用,在方法里赋值,因为返回值只有一个,而我要在方法外得到2个值,只能用引用的方式。
最后改成另一种写法就好了,在调用的时候不加 & 符号,而在定义的时候加&符号,效果是一样的。
什么意思呢?举个例子:
function a($p1,$p2){
$p2=333;
return $p1+$p2;
} a(22,&$p);
//原本写法是这样的 ,在这里调用完a后$p的值为333,没错,但正因为这样写就出现上述错误。
最后将写法改为:
function a($p1,&$p2){
$p2=333;
return $p1+$p2;
} a(22,$p);
//这样调用完a后$p的值也是333,而解决了上述问题
至于什么原因,我也不清楚。在Debug=true时两种写法都OK,但Debug=false时第一种写法就会报错!也许第一种写法是PHP新语法吧,目前网上的资料都是第二种写法,我上次无意中发现第一种写法也可行于是就用了第一种写法,没想到会出现这种错误,哎。。。
ThinkPHP报Class 'Core\Log' not found竟然是由这个原因导致的的更多相关文章
- .NET CORE LOG
.NET CORE LOG 合格的应用程序不仅要求运行的高效和计算的准确,稳定及可靠性也要得到满足,同事,系统的可维护性也相当重要.谈及到可维护性,就必须涉及到系统运行状态的监控和异常的快速定位与跟踪 ...
- 新引入thinkphp报错“应用目录[./Application/]不可写,目录无法自动生成! 请手动生成项目目录~”
新引入thinkphp报错“应用目录[./Application/]不可写,目录无法自动生成! 请手动生成项目目录~”, 其主要原因是文件夹的权限问题,手动将项目文件夹权限更改为可读可写就OK,具体操 ...
- Vue热更新报错(log.error('[WDS] Errors while compiling. Reload prevented.'))
log.error('[WDS] Errors while compiling. Reload prevented.');中的WDS其实是webpack-dev-serverwebpack的意思,用来 ...
- thinkphp报错Call to undefined method app\index\controller\Index::fetch()
因为要写一个系统,所以又重新下载了thinkphp,然后安装了一下.回忆起这个问题很容易让新手朋友费解.会出现如下报错:Call to undefined method app\index\contr ...
- loadrunner12-查看controller运行报错详细log
1.路径为controller-->results-->results setting 2.打开文件夹res/log/***.log,里面会有当前场景运行的log日志. 注:启用这个首先保 ...
- 第一次用THINKPHP 报路径错
我第一次 看网上写的代码 define('THINK_PATH','ThinkPHP');define('App_NAME','43');define('App_PATH','.'); require ...
- ThinkPHP报错处理
1,当运行结果提示:找不到该页面(控制器),怎么办? 建造一个空页面:EmptyController <?php namespace Home\Controller; use Think\Con ...
- Thinkphp报错 -- “_STORAGE_WRITE_ERROR_”
磁盘满了 没有写入权限 解决方法: chmod -R 777 Runtime目录路径
- vue报错如log,如果其他项目运行没问题,很有可能是代码错误 加externals报错
随机推荐
- java基础之开发环境配置
一. 环境变量配置的原理 一. 配置环境变量path 如果我们按照上面的来编译和运行的话未免太过于麻烦了,那么在这里我们可以配置环境变量PATH 1.配置环境变量的步骤 这时可以直接来看效果 如果d ...
- Tarjan缩点+LCA【洛谷P2416】 泡芙
P2416 泡芙 题目描述 火星猫经过一番努力终于到达了冥王星.他发现冥王星有 N 座城市,M 条无向边.火星猫准备出发去找冥王兔,他听说有若干泡芙掉落在一些边上,他准备采集一些去送给冥王兔.但是火星 ...
- kuangbin专题十六 KMP&&扩展KMP POJ2752 Seek the Name, Seek the Fame
The little cat is so famous, that many couples tramp over hill and dale to Byteland, and asked the l ...
- Python集合字典运算符
1.集合2.字典3.运算符优先级 1.集合 创建:{} set([]) 注意:创建空的集合要用set() 特点:元素唯一,无序 运算: & 交集 | 并集 - 差集 方法: s ...
- CPU和微架构的概念
CPU是什么: 中央处理器(CPU,Central Processing Unit)是一块超大规模的集成电路,是一台计算机的运算核心(Core)和控制核心( Control Unit). 它的功能主要 ...
- P2896 [USACO08FEB]一起吃饭Eating Together
传送门 可以考虑DP 设 f [ i ] [ 1/2/3 ] [ 0/1 ] 表示当前考虑到第 i 头牛,打算让当前位置的编号变成 1/2/3,并且打算让整段序列上升/下降 0/1 然后就对每种情况慢 ...
- c#缓存帮助类
public static class CacheHelper { static object _lockObj = new object(); private static Dictionary&l ...
- my07_lock-tables与single-transaction的区别
概念描述 ************************************************************ mysqldump进行逻辑备份时(innodb),为保证事务的一致性 ...
- php 数据库查询order by 与查询返回的数据类型
<?php /** * Created by PhpStorm. * User: DY040 * Date: 2017/11/24 * Time: 9:40 * * 从结果集合中读取一行数据 * ...
- math.random()方法的使用
一:导言 以前总是被数字的范围正则搞的头大,在此总结了一下 二:用法 Math.random()函数返回0和1之间的伪随机数,可能为0,但总是小于1,[0,1) 生成n-m,包含n但不包含m的整数: ...