0

mysql インジェクションを回避するにはどうすればよいですか? これは私が今持っているPHPファイルです

<?php
include 'config.php';

$Name = $_GET['Name'] ;

$sql = "Select * from tables where names =\"$Name\"";



try {
    $dbh = new PDO("mysql:host=$dbhost;dbname=$dbname", $dbuser, $dbpass);
    $dbh->query('SET CHARACTER SET utf8');
    $dbh->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
    $stmt = $dbh->query($sql);  
    $names = $stmt->fetchAll(PDO::FETCH_OBJ);
    $dbh = null;
    echo '{"key":'. json_encode($names) .'}'; 
} catch(PDOException $e) {
    echo '{"error":{"text":'. $e->getMessage() .'}}'; 
}


?>

コードを入れるとうまくいき$stmt = $dbh->query($sql); $stmt->execute(array(':name' => $name));ません。では、どうすればいいですか?

4

1 に答える 1

7

pdo 準備済みステートメントについて読む

ここに例があります

$stmt = $dbh->prepare("SELECT * FROM tables WHERE names = :name");
$stmt->execute(array(':name' => $name));
于 2012-06-07T09:27:43.490 に答える