首頁  >  文章  >  後端開發  >  ThinkPHP提交表單時預設自動轉義的解決方法

ThinkPHP提交表單時預設自動轉義的解決方法

不言
不言原創
2018-06-06 15:52:391210瀏覽

這篇文章主要介紹了ThinkPHP提交表單時預設自動轉義的解決方法,可解決針對單引號和雙引號的自動轉移問題,提供了兩種解決方法供大家對比選擇,具有一定的實用價值,需要的朋友可以參考下

本文實例講述了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自動驗證失敗的解決方法

#thinkphp實作excel資料的匯入匯出(附完整案例)

以上是ThinkPHP提交表單時預設自動轉義的解決方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn