分號不會引起任何問題。
使用準備好的語句。
在mysqli:
$stmt = $dbConnection->prepare('SELECT * FROM employees WHERE name = ?');
$stmt->bind_param('s', $name);
$stmt->execute();
$result = $stmt->get_result();
while ($row = $result->fetch_assoc()) {
// do something with $row
}
在PDO:
$stmt = $pdo->prepare('SELECT * FROM employees WHERE name = :name');
$stmt->execute(array(':name' => $name));
foreach ($stmt as $row) {
// do something with $row
}
使用mysql_real_escape_string
$unsafe_variable = $_POST["user-input"];
$safe_variable = mysql_real_escape_string($unsafe_variable);
mysql_query("INSERT INTO table (column) VALUES ('" . $safe_variable . "')");
檢查這個問題,以瞭解更多信息How can I prevent SQL injection in PHP?
我從來沒有聽說過分號是一個問題。你能舉一個你正在輸入的例子嗎? – 2013-04-27 02:59:32
另外,您不需要檢測SQL注入,您需要使所有輸入都是良性的。 – 2013-04-27 03:00:23
我還沒有針對問題1的答案,但對於2,您可以做的是使用準備好的語句。 – 2013-04-27 03:00:31