用PHP函數解決SQL injection 反斜杠
什麼是魔術引號
當打開時,所有的 '(單引號),"(雙引號),(反斜線)和 NULL 字符都會被自動加上一個反斜線進行轉義。這和 addslashes( ) 作用完全相同。
magic_quotes_runtime 如果開啟的話,大部份從外部來源取得資料並傳回的函數,包括從資料庫和文字文件,所傳回的資料都會被反斜線轉義。中的預設值為 off。兩個選項的話,單引號將會被轉義成 ''。反斜線引用字串
說明
string addslashes ( string $str )
回傳字串,該字串為了資料庫查詢語句等的需求在某些字元前加上了反斜線。引號(')、雙引號(")、反斜線()與NUL(NULL 字元)。
一個使用 addslashes() 的範例是當你要在資料庫中輸入資料時。例如,將名字 O'reilly 插入資料庫中,這就需要對其進行轉義。大多資料庫使用 作為轉義符:O'reilly。這樣可以將資料放入資料庫中,而不會插入額外的 。當 PHP 指令 magic_quotes_sybase 被設定為 on 時,表示插入 ' 時將使用 ' 轉義。
SQL injection問題在ASP上可是鬧得沸沸揚揚?5比換褂簧難搞」。至於SQL injection的詳情,網路上的文章太多了,在此就不作介紹。
如果你網站空間的php.ini文件裡的magic_quotes_gpc設為了off,那麼PHP就不會在敏感字符前加上反斜杠(),由於表單提交的內容可能含有敏感字符,如單引號(' ),就導致了SQL injection的漏洞。在這種情況下,我們可以用addslashes()來解決問題,它會自動在敏感字元前面加上反斜線。但是,上面的方法只 適用於magic_quotes_gpc=Off的情況。身為開發者,你不知道每個使用者的magic_quotes_gpc是On還是Off,如果把 全部的資料都用上addslashes(),那不是「濫殺無辜」了?假如magic_quotes_gpc=On,並且又用了addslashes()函數,那讓我們來看看:
//如果從表單提交一個變數$_POST['message'],內容為Tom's book
//這此加入連接MySQL資料庫的程式碼,自己寫吧
//在$_POST['message']的敏感字元前加上反斜線$_POST['message'] = addslashes($_POST['message'] );
//由於magic_quotes_gpc=On,所以又一次在敏感字元前面加上反斜線
$sql = "INSERT INTO msg_table VALUE('$_POST[message]');";//發送請求,把內容儲存到資料庫內$query = mysql_query($sql);
//如果你再從資料庫內提取這個記錄並輸出,就會看到Tom's book
?>
這樣的話,在magic_quotes_gpc=On的環境裡,所有輸入的單引號(')都會變成(')…
其實我們可以用get_magic_quotes_gpc()函數輕易地解決這個問題。當magic_quotes_gpc=On時,函數傳回TRUE;當magic_quotes_gpc=Off時,傳回FALSE。至此,肯定已經有不少人意識到:問題已經解決。請看代碼:
//如果magic_quotes_gpc=Off,那就為提單提交的$_POST['message']裡的敏感字元加反斜線
//magic_quotes_gpc=On的情況下,則不加
if (! get_magic_quotes_gpc()) {
$_POST['message'] = addslashes($_POST['message']);
} else {}
?>
其實說到這裡,問題已經解決。下面再說一個小技巧。
有時表單提交的變數不只一個,可能有十幾個,幾十個。那麼一次一次地複製/貼上貼文addslashes(),是否麻煩了一點?由於從表單或URL取得的資料都是以陣列形式出現的,如$_POST、$_GET)?D薔妥遠ㄒ逡桓隹梢浴昂嶸ㄇЬ?」的函數:
function quotes($content)
{
//如果magic_quotes_gpc=Off,那麼就開始處理
if (!get_magic_quotes_gpc()) {
//判斷$content是否為數組
if (is_array($content)) {
//如果$content是數組,那就處理它的每一個單無
foreach ($content as $key=>$value) {
$content[$key] = addslashes($value);
}
} else {
//如果$content不是數組,那就只處理一次
addslashes($content);
}
} else {
//如果magic_quotes_gpc=On,那就不處理
}
//返回$content
return $content ;
}
?>

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

PHP和Python各有優勢,選擇依據項目需求。 1.PHP適合web開發,尤其快速開發和維護網站。 2.Python適用於數據科學、機器學習和人工智能,語法簡潔,適合初學者。

PHP是一種廣泛應用於服務器端的腳本語言,特別適合web開發。 1.PHP可以嵌入HTML,處理HTTP請求和響應,支持多種數據庫。 2.PHP用於生成動態網頁內容,處理表單數據,訪問數據庫等,具有強大的社區支持和開源資源。 3.PHP是解釋型語言,執行過程包括詞法分析、語法分析、編譯和執行。 4.PHP可以與MySQL結合用於用戶註冊系統等高級應用。 5.調試PHP時,可使用error_reporting()和var_dump()等函數。 6.優化PHP代碼可通過緩存機制、優化數據庫查詢和使用內置函數。 7

PHP在電子商務、內容管理系統和API開發中廣泛應用。 1)電子商務:用於購物車功能和支付處理。 2)內容管理系統:用於動態內容生成和用戶管理。 3)API開發:用於RESTfulAPI開發和API安全性。通過性能優化和最佳實踐,PHP應用的效率和可維護性得以提升。

PHP和Python各有優勢,選擇應基於項目需求。 1.PHP適合web開發,語法簡單,執行效率高。 2.Python適用於數據科學和機器學習,語法簡潔,庫豐富。

PHP仍然具有活力,其在現代編程領域中依然佔據重要地位。 1)PHP的簡單易學和強大社區支持使其在Web開發中廣泛應用;2)其靈活性和穩定性使其在處理Web表單、數據庫操作和文件處理等方面表現出色;3)PHP不斷進化和優化,適用於初學者和經驗豐富的開發者。

PHP適合web開發,特別是在快速開發和處理動態內容方面表現出色,但不擅長數據科學和企業級應用。與Python相比,PHP在web開發中更具優勢,但在數據科學領域不如Python;與Java相比,PHP在企業級應用中表現較差,但在web開發中更靈活;與JavaScript相比,PHP在後端開發中更簡潔,但在前端開發中不如JavaScript。

PHP和Python各有優劣,選擇取決於項目需求和個人偏好。 1.PHP適合快速開發和維護大型Web應用。 2.Python在數據科學和機器學習領域佔據主導地位。

PHP主要是過程式編程,但也支持面向對象編程(OOP);Python支持多種範式,包括OOP、函數式和過程式編程。 PHP適合web開發,Python適用於多種應用,如數據分析和機器學習。
