標籤:filename define storage name 上傳 自己 代碼 自動 組合
解決ThinkPHP關閉偵錯模式時報錯的問題匯總
案例一:
最近用ThinkPHP開發一個項目,本地開發測試完成上傳到伺服器後,第一次開啟正常,再重新整理頁面時就出現 “頁面調試錯誤,無法找開頁面,請重試”的錯誤.
明明本地設定define(‘APP_DEBUG’, false) 運行沒點問題,怎麼放到伺服器上就出錯了昵?
baidu,Google還是沒有找到解決方案,突然發現項目APP_Name/Runtime/Cache目錄和APP_Name/Runtime/Logs目錄沒有可寫入權限,果斷更改!
案例二:
ThinkPHP 將 APP_DEBUG 常量設定為 false 後出現了類似下面的問題:
複製代碼代碼如下:Parse error: syntax error, unexpected T_STRING in E:\PHPnow\htdocs\ojbak\Runtime\~app.php on line 1
或者直接報”伺服器錯誤”, 怎麼辦?
這個和 PHP 有關係,在 php.ini 裡修改配置
複製代碼代碼如下:short_open_tag = On
因為 app.class.php 裡面的 build 方法:
當開啟了偵錯模式後,會擷取相關檔案的內容 然後重新組合成檔案 這個時候是會自動加上 的
也就是你看到的 ~app.php 檔案了
但是當你不開啟偵錯模式後,會每次都會載入相關的檔案,這樣子,你的錯誤就暴露出來了。
案例三:
在thinkphp中將APP_DEBUG設定為false之後,資料查詢(select, find等等)總是顯示第一條。。但是把APP_DEBUG設定為true之後,就正常了。。這是為什嗎?有什麼解決方案嗎?
正常來說,APP_DEBUG是偵錯模式,放到線上環境,盡量要設定為false的。。
自己找一個select查詢,在關閉debug的情況下,用寫檔案的方式調試下查詢後產生的sql。
以上所述就是本文的全部內容了,希望大家能夠喜歡。
裝載地址:http://www.jb51.net/article/64552.htm
ThinkPHP3.2.2偵錯模式下正常訪問,關閉偵錯模式,部署時出現刪出緩衝第一次沒錯,第二次開始錯誤。
我碰到的錯誤如下:
ThinkPHP3.2.2 { Fast & Simple OOP PHP Framework } — [ WE CAN DO IT JUST THINK ]
:
看到網上大多數人都碰到,但沒很好解決,確實很頭痛,沒辦法只能去閱讀源碼。在同事的協助下,就愉快地去翻源,看架構執行流程:
1.從入口檔案開始:index.php 裡面有這句(require ‘./ThinkPHP/ThinkPHP.php’;),跳到ThinkPHP.php;
2.ThinkPHP.php 裡面的96行:Think\Think::start();可以看到,跑這函數裡面去了,跳到Think.class.php;
3.Think.class.php 因為是部署模式,所以執行到裡面的42行Storage::load($runtimefile);發現沒法跳了。直接去找ThinkPHP/Library/Storage.class.php;
4.Storage.class.php; 源碼:static public function connect($type=’File’,$options=array()) {
$class = ‘Think\\Storage\\Driver\\’.ucwords($type);
self::$handler = new $class($options);
}
我們看到,它去取到了一個叫“Flie”的檔案,找了下在找到了它ThinkPHP/Library/Storage/File.class.php,開啟看看。
5.File.class.php 裡面果然有第3步的load方法,在代碼75行。public function load($_filename,$vars=null){
if(!is_null($vars))
extract($vars, EXTR_OVERWRITE);
include $_filename;
}
最後鎖定,錯誤是發生在這句代碼。
6.可以測試下結果:(1).
public function load($_filename,$vars=null){
if(!is_null($vars))
extract($vars, EXTR_OVERWRITE);
echo $_filename;
die();
include $_filename;
}
結果如下:
(2)刪掉緩Runtime存再測.
public function load($_filename,$vars=null){
if(!is_null($vars))
extract($vars, EXTR_OVERWRITE);
include $_filename;
echo $_filename;
die();
}
結果如下:
7.第6步結果可以看到,問題就出在include 這個檔案./Application/Runtime/common~runtime.php時出錯了。為什麼呢?
檔案如下:
8.在同事協助下,終於知道原因,是因為我Common/Common檔案夾下的function.php引入了一個user.function.php路徑有問題。
如果直接用require_once ‘user.function.php’;這樣在部署情況下common~runtime.php就沒辦法正確解析,之前偵錯模式是沒問題的。
最後我們在匯入檔案的時候加上正確路徑就可以了:改成require_once APP_PATH.’Common/Common/’user.function.php’;,問題到這裡就解決了。
最後再說明一點:記得關閉偵錯模式,要把Runtime檔案夾刪除,到時測試成功通過。
轉載地址:http://blog.csdn.net/u012728971/article/details/47152745
解決ThinkPHP關閉偵錯模式時報錯的問題匯總