本文實例講述了ThinkPHP提交表單時默認自動轉義的解決方法。分享給大家供大家參考。具體方法如下:
一、問題:
在ThinkPHP中提交表單插入數據的時候,單引號和雙引號是會被自動轉義的,就是會自動的加上反斜線,但是我不想給單引號和雙引號加上反斜線.
在ThinkPHP中提交表單插入數據的時候,單引號和雙引號是會被自動轉義的,就是會自動的加上反斜線,但是我不想給單引號和雙引號加上反斜線,在ThinkPHP中提交表單插入數據的時候,單引號和雙引號是會被自動轉義的,就是會自動的加上反斜線,但是我不想給單引號和雙引號加上反斜線,如:hds"gh"j'g'h 會被自動轉義為:hds\"gh\"j\'g\'h.
請注意需要的是取消這個轉義的功能,而不是使用stripslashes() 函數刪除這些反斜槓,即不需要官方的這個自動轉義的功能.
二、解決方法:
在網上搜索到解決方法:
1、在thinkphp目錄下,依次打開 ThinkPHP\Lib\Driver\Db 目錄,並在dbmysql.class.php 這個文件中把 escapeString 函數的函數修改成:
復制代碼 代碼如下:public function escapeString($str) {
//修改 周蠻子 放雙引號雙重轉義
if (!get_magic_quotes_gpc()){
if($this->_linkID) {
return mysql_real_escape_string($str,$this->_linkID);
}else{
return mysql_escape_string($str);
}
} else {
return $str;
}
}
原函數:
復制代碼 代碼如下:public function escapeString($str) {
//修改 周蠻子 放雙引號雙重轉義
if($this->_linkID) {
return mysql_real_escape_string($str,$this->_linkID);
}else{
return mysql_escape_string($str);
}
}
2、在公共文件中加入:
復制代碼 代碼如下://防止雙重轉義
if (get_magic_quotes_gpc()) {
function stripslashes_deep($value){
$value = is_array($value) ?
array_map('stripslashes_deep', $value) :
stripslashes($value);
return $value;
}
$_POST = array_map('stripslashes_deep', $_POST);
$_GET = array_map('stripslashes_deep', $_GET);
$_COOKIE = array_map('stripslashes_deep', $_COOKIE);
}
注:如果服務器開了轉義,那麼就經過thinkphp再次轉義後,就會在程序中產生雙重轉義的Bug
經過修改後,我的網站程序後台錄入就沒什麼問題了,看來大家以後如果有碰到使用Thinkphp時,注意如果服務器開啟了過濾單引號或雙引號的,可能就會跟ThinkPHP起沖突的了,所以加一層判斷,就可以很好的解決這個問題了.
希望本文所述對大家的ThinkPHP框架程序設計有所幫助。