magic_quotes_gpc函數(shù)在php中的作用是判斷解析用戶提示的數(shù)據(jù),如包括有:post、get、cookie過來的數(shù)據(jù)增加轉義字符“\\”,以確保這些數(shù)據(jù)不會引起程序,特別是數(shù)據(jù)庫語句因為特殊字符引起的污染而出現(xiàn)致命的錯誤.
在magic_quotes_gpc=On的情況下,如果輸入的數(shù)據(jù)有
單引號(’)、雙引號(”)、反斜線()與 NUL(NULL 字符)等字符都會被加上反斜線,這些轉義是必須的,如果這個選項為off,那么我們就必須調用addslashes這個函數(shù)來為字符串增加轉義.
正是因為這個選項必須為On,但是又讓用戶進行配置的矛盾,在PHP6中刪除了這個選項,一切的編程都需要在magic_quotes_gpc=Off下進行了,在這樣的環(huán)境下如果不對用戶的數(shù)據(jù)進行轉義,后果不僅僅是程序錯誤而已了,同樣的會引起數(shù)據(jù)庫被注入攻擊的危險,所以從現(xiàn)在開始大家都不要再依賴這個設置為On了,以免有一天你的服務器需要更新到PHP6而導致你的程序不能正常工作.
當magic_quotes_gpc=On的時候,函數(shù)get_magic_quotes_gpc()就會返回1
當magic_quotes_gpc=Off的時候,函數(shù)get_magic_quotes_gpc()就會返回0
因此可以看出這個get_magic_quotes_gpc()函數(shù)的作用就是得到環(huán)境變量magic_quotes_gpc的值。既然在PHP6中刪除了magic_quotes_gpc這個選項,那么在PHP6中這個函數(shù)我想也已經不復存在了。
php 判斷是否開啟get_magic_quotes_gpc功能了,以方便我們是否決定使用addslashes這個函數(shù)了,代碼如下:
- function SQLString($c, $t){
- $c=(!get_magic_quotes_gpc())?addslashes($c):$c;
- switch($t){
- case 'text':
- $c=($c!='')?"'".$c."'":'NULL';
- break;
- case 'search':
- $c="'%%".$c."%%'";
- break;
- case 'int':
- $c=($c!='')?intval($c):'0';
- break;
- }
- return $c;
- }
預防數(shù)據(jù)庫攻擊的正確做法,代碼如下:
轉載請注明來源:php get_magic_quotes_gpc()函數(shù)用法介紹
- <?php
- function check_input($value)
- {
- // 去除斜杠
- if (get_magic_quotes_gpc())
- {
- $value = stripslashes($value);
- }
- // 如果不是數(shù)字則加引號
- 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());
- }//開源軟件:phpfensi.com
- // 進行安全的 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);
- ?>
哈爾濱品用軟件有限公司致力于為哈爾濱的中小企業(yè)制作大氣、美觀的優(yōu)秀網(wǎng)站,并且能夠搭建符合百度排名規(guī)范的網(wǎng)站基底,使您的網(wǎng)站無需額外費用,即可穩(wěn)步提升排名至首頁。歡迎體驗最佳的哈爾濱網(wǎng)站建設。
