PHP 轉義詳解_PHP教程

來源:互聯網
上載者:User
php中資料的魔法引用函數 magic_quotes_gpc 或 magic_quotes_runtime

設定為on時,為我們引用的資料碰到 單引號' 和 雙引號" 以及 反斜線\ 時自動加上反斜線,幫我們自動轉譯符號,確保資料操作的正確運行
兩者的區別:

magic_quotes_gpc
作用範圍是:WEB客戶服務端;
作用時間:請求開始是,例如當指令碼運行時。

magic_quotes_runtime
作用範圍:從檔案中讀取的資料或執行exec()的結果或是從SQL查詢中得到的;
作用時間:每次當指令碼訪問運行狀態中產生的資料。

可以看出
magic_quotes_gpc的設定值將會影響通過Get/Post/Cookies獲得的資料
magic_quotes_runtime的設定值將會影響從檔案中讀取的資料或從資料庫查詢得到的資料

幾個想關聯的函數:

set_magic_quotes_runtime():
設定magic_quotes_runtime值. 0=關閉.1=開啟.預設狀態是關閉的.可以通過 echo phpinfo(); 查看magic_quotes_runtime
get_magic_quotes_gpc():
查看magic_quotes_gpc值.0=關閉.1=開啟
get_magic_quotes_runtime():
查看magic_quotes_runtime值。0=關閉.1=開啟.
注意的是沒有 set_magic_quotes_gpc()這個函數,就是不能在程式裡面設定magic_quotes_gpc的值。

由於兩個值的設定問題,會給編程時造成部分混淆或者會多加一次轉義,針對這種情況,需要在程式開始的時候進行設定和判斷,或者預設配置
這兩個值都關閉。轉義部分通過程式來執行。

保證資料插入資料時正常 通常會使用 addslashes 這個來處理, 資料讀出時多用 stripslashes 來去掉加的反斜線

php中類似的字元轉換的函數
addslashes 指定的預定義字元前添加反斜線
stripslashes 刪除由 addslashes() 函數添加的反斜線
htmlspecialchars 把一些預定義的字元轉換為 HTML 實體
htmlspecialchars_decode 把一些預定義的 HTML 實體轉換為字元
html_entity_decode() 把 HTML 實體轉換為字元
htmlentities() 把字元轉換為 HTML 實體

http://www.bkjia.com/PHPjc/440407.htmlwww.bkjia.comtruehttp://www.bkjia.com/PHPjc/440407.htmlTechArticlephp中資料的魔法引用函數 magic_quotes_gpc 或 magic_quotes_runtime 設定為on時,為我們引用的資料碰到 單引號' 和 雙引號" 以及 反斜線\ 時自動加上...

  • 聯繫我們

    該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

    如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

    A Free Trial That Lets You Build Big!

    Start building with 50+ products and up to 12 months usage for Elastic Compute Service

    • Sales Support

      1 on 1 presale consultation

    • After-Sales Support

      24/7 Technical Support 6 Free Tickets per Quarter Faster Response

    • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.