使用 PDO 针对 SQL 注入的保护查询

Protection query against SQL injection, using PDO

提问人:strejcekmichal 提问时间:11/3/2023 最后编辑:Bill Karwinstrejcekmichal 更新时间:11/3/2023 访问量:36

问:

请问您如何防止SQL注入?

我有

$podminkazeme = "";
$podminkakraj = "";

if ( isset( $_GET[ "zeme" ] )and !empty( $_GET[ "zeme" ] ) ) {
   $podminkazeme = "and nb.zemehledani in (" . str_replace( '%2C', ',',  $_GET[ "zeme" ] ) . ")";
};

if ( isset( $_GET[ "kraj" ] )and !empty( $_GET[ "kraj" ] ) ) {
  $podminkakraj = "and nb.krajhledani in (" . str_replace( '%2C', ',', $_GET[ "kraj" ]  ) . ")";
};

$conn = new PDO( DB_DSN, DB_USERNAME, DB_PASSWORD );
$sqljednotkaa = "
  select nb.*, 
    dv.nazev as developer, 
    UNIX_TIMESTAMP(nb.datumAktualizace) as datumAktualizace, 
    UNIX_TIMESTAMP(nb.datumPripomenuti) as datumPripomenuti, 
    uz.nazev as skladUpravil, 
    uzm.nazev as makler, 
    tp.nazev as typProdeje, 
    dal.nazev as nazevdalnice
  from nabidka nb 
  left join uzivatele uz on uz.id=nb.skladUpravil 
  left join uzivatele uzm on uzm.id=nb.makler 
  left join typProdeje tp on tp.id=nb.typProdeje 
  left join developer dv on dv.id=nb.developer
  left join dalnice dal on dal.id=nb.dalnice 
  where nb.emptyid is null 
    $podminkaid 
    $podminkastav 
    $podminkaupraveno 
    $podminkavelikost 
    $podminkacena 
    $podminkamakler 
    $podminkaexport 
    $podminkatypprodeje 
    $podminkatypnemovitosti 
    $podminkazeme 
    $podminkadalnice 
    $podminkakraj 
    $podminkaokres 
    $podminkadeveloper 
    $podminkatechnickeparametry 
    $podminkahledanislovo 
  order by nb.emptyid asc $razenipodminka";

$stjednotkaa = $conn->prepare( $sqljednotkaa );
$stjednotkaa->execute();
SQL注入

评论


答:

0赞 Tomáš Strejček 11/3/2023 #1

试试这个

$conditions = [];
$parameters = [];

if (isset($_GET["zeme"]) && !empty($_GET["zeme"])) {
    $zemeValues = explode(',', $_GET["zeme"]);
    $conditions[] = "nb.zemehledani IN (" . implode(', ', array_fill(0, count($zemeValues), '?')) . ")";
    $parameters = array_merge($parameters, $zemeValues);
}

if (isset($_GET["kraj"]) && !empty($_GET["kraj"])) {
    $krajValues = explode(',', $_GET["kraj"]);
    $conditions[] = "nb.krajhledani IN (" . implode(', ', array_fill(0, count($krajValues), '?')) . ")";
    $parameters = array_merge($parameters, $krajValues);
}

$conn = new PDO(DB_DSN, DB_USERNAME, DB_PASSWORD);
$sqljednotkaa = "SELECT nb.*, dv.nazev as developer, UNIX_TIMESTAMP(nb.datumAktualizace) as datumAktualizace, UNIX_TIMESTAMP(nb.datumPripomenuti) as datumPripomenuti, uz.nazev as skladUpravil, uzm.nazev as makler, tp.nazev as typProdeje, dal.nazev as nazevdalnice from nabidka nb left join uzivatele uz on uz.id=nb.skladUpravil left join uzivatele uzm on uzm.id=nb.makler left join typProdeje tp on tp.id=nb.typProdeje left join developer dv on dv.id=nb.developer left join dalnice dal on dal.id=nb.dalnice where nb.emptyid is null";
if ($conditions) {
    $sqljednotkaa .= " AND " . implode(" AND ", $conditions);
}
$sqljednotkaa .= " ORDER BY nb.emptyid ASC $razenipodminka";
$stjednotkaa = $conn->prepare($sqljednotkaa);
$stjednotkaa->execute($parameters);