程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> 關於PHP編程 >> 快速掌握PHP引號轉義原理

快速掌握PHP引號轉義原理

編輯:關於PHP編程

我們在運用

PHP中有三個設置可以實現自動對’(單引號),”(雙引號),(反斜線)和 NULL 字符轉移。

PHP稱之為魔術引號,這三項設置分別是

magic_quotes_gpc

影響到 HTTP 請求數據(GET,POST 和 COOKIE)。不能在運行時改變。在 PHP 中默認值為 on。

magic_quotes_runtime

如果打開的話,大部份從外部來源取得數據並返回的函數,包括從數據庫和文本文件,所返回的數據都會被反斜線轉義。該選項可在運行的時改變,在 PHP 中的默認值為 off。

magic_quotes_sybase

如果打開的話,將會使用單引號對單引號進行PHP引號轉義而非反斜線。此選項會完全覆蓋 magic_quotes_gpc。如果同時打開兩個選項的話,單引號將會被轉義成 ”。而雙引號、反斜線 和 NULL 字符將不會進行轉義。

雖然方便的實現了對特殊符號的自動PHP引號轉義,但是這樣會使得程序效率降低,並導致程序可移植變得麻煩。在不知道服務器ini設置的情況下,還需要調用get_magic_quotes_gpc() ,get_magic_quotes_runtime() 或ini_get()來檢測狀態。

例如:

  1. if (!get_magic_quotes_gpc()) {  
  2. $lastname = addslashes
    ($_POST['lastname']);  
  3. } else {  
  4. $lastname = $_POST['lastname'];  
  5. }   

因此最好關閉php的魔術引號,根據情況手動用addslashes(),stripslashes()來轉義和取消PHP引號轉義。可以學習discuz的做法,在配置文件中加入set_magic_quotes_runtime(0);來取消轉義。


  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved