php中get_magic_quotes_gpc()函數說明
get_magic_quotes_gpc函數是一個用來判斷是否為用戶提供的數據增加斜線了,這個在php.ini配置文件中哦,下面我來介紹一下get_magic_quotes_gpc()函數說明.
get_magic_quotes_gpc函數介紹
取得 PHP 環(huán)境變數 magic_quotes_gpc 的值,屬于 PHP 系統(tǒng)功能。
語法: long get_magic_quotes_gpc(void);
返回值: 長整數
本函數取得 PHP 環(huán)境配置的變量 magic_quotes_gpc (GPC, Get/Post/Cookie) 值。返回 0 表示關閉本功能;返回 1 表示本功能打開。
當 magic_quotes_gpc 打開時,所有的 ‘ (單引號), ” (雙引號), (反斜線) and 空字符會自動轉為含有反斜線的溢出字符。
magic_quotes_gpc設置是否自動為GPC(get,post,cookie)傳來的數據中的'”加上反斜線??梢杂胓et_magic_quotes_gpc()檢測系統(tǒng)設置。
如果沒有打開這項設置,可以使用addslashes()函數添加,它的功能就是給數據庫查詢語句等的需要在某些字符前加上了反斜線。
這些字符是單引號(')、雙引號(”)、反斜線()與 NUL(NULL 字符)。
默認情況下,PHP 指令 magic_quotes_gpc 為 on,它主要是對所有的 GET、POST 和 COOKIE 數據自動運行 addslashes()。
不要對已經被 magic_quotes_gpc 轉義過的字符串使用 addslashes(),因為這樣會導致雙層轉義。遇到這種情況時可以使用函數 get_magic_quotes_gpc() 進行檢測。
例
利用 get_magic_quotes_gpc()預防數據庫攻擊的正確做法
代碼如下
<?php function check_input($value) { // 去除斜杠 if (get_magic_quotes_gpc()) { $value = stripslashes($value); } // 如果不是數字則加引號 if (!is_numeric($value)) { $value = “‘” . mysql_real_escape_string($value) . “‘”; } return $value; } $con = mysql_connect(“l(fā)ocalhost”, “hello”, “321″); if (!$con) { die(‘Could not connect: ‘ . mysql_error()); } // 進行安全的 SQL $user = check_input($_POST['user']); $pwd = check_input($_POST['pwd']); $sql = “SELECT * FROM users WHERE user=$user AND password=$pwd”; mysql_query($sql); mysql_close($con); ?>
總結如下:
1. 對于magic_quotes_gpc=on的情況,
我們可以不對輸入和輸出數據庫的字符串數據作
addslashes()和stripslashes()的操作,數據也會正常顯示。
如果此時你對輸入的數據作了addslashes()處理,
那么在輸出的時候就必須使用stripslashes()去掉多余的反斜杠。
2. 對于magic_quotes_gpc=off 的情況
必須使用addslashes()對輸入數據進行處理,但并不需要使用stripslashes()格式化輸出
因為addslashes()并未將反斜杠一起寫入數據庫,只是幫助mysql完成了sql語句的執(zhí)行
以上就是本文的全部內容,希望本文的內容對大家的學習或者工作能帶來一定的幫助,同時也希望多多支持腳本之家!
- 使用mysqldump如何實現數據庫表備份
- PHP函數篇詳解十進制、二進制、八進制和十六進制轉換函數說明
- PHP訪問MYSQL數據庫封裝類(附函數說明)
- php 數組操作(增加,刪除,查詢,排序)等函數說明
- php中magic_quotes_gpc對unserialize的影響分析
- 基于PHP magic_quotes_gpc的使用方法詳解
- PHP5下$_SERVER變量不再受magic_quotes_gpc保護的彌補方法
- php magic_quotes_gpc的一點認識與分析
- PHP 字符串正則替換函數preg_replace使用說明
- php array_map()數組函數使用說明
- PHP中simplexml_load_string函數使用說明
相關文章
WordPress開發(fā)中用于標題顯示的相關函數使用解析
這篇文章主要介紹了WordPress開發(fā)中用于標題顯示的相關函數使用解析,講解了single_cat_title函數和get_the_title函數和the_title函數的用法,需要的朋友可以參考下2016-01-01php函數之strtr和str_replace的用法詳解以及效率分析
PHP中主要用strtr()和str_repalce()這兩個函數替換字符串和數組,但你們都知道他們這兩個函數的區(qū)別和用法嗎?有不少文章在說使用strtr函數比str_replace快4倍,那為什么很多時候都在用str_replace,到底應該使用哪個函數呢2022-11-11