Ver Mensaje Individual
  #1 (permalink)  
Antiguo 11/01/2011, 15:50
RodrigoG
 
Fecha de Ingreso: diciembre-2009
Ubicación: dirname(__FILE__)
Mensajes: 149
Antigüedad: 14 años, 4 meses
Puntos: 11
PDO e Inyección SQL

Hola comunidad!

Por ahí leí que PDO evita el SQL Injection, pero no sé como, tengo tres ejemplos inspirados en los del manual PHP que permiten hacer consultas con PDO, ¿Cuál de todos me evita la inyección SQL?
Desde ya muchas gracias

Forma 1 (con array):
Código PHP:
Ver original
  1. <?php
  2. /* Execute a prepared statement by passing an array of values */
  3. $sql = 'SELECT name, colour, calories
  4.    FROM fruit
  5.    WHERE calories < :calories AND colour = :colour';
  6. $sth = $dbh->prepare($sql, array(PDO::ATTR_CURSOR => PDO::CURSOR_FWDONLY));
  7. $sth->execute(array(':calories' => $_GET['calorias'], ':colour' => $_GET['color']));
  8. // Imprimir el resultado.
  9. print_r($sth->fetchAll());
  10. ?>

Forma 2 (bindParam):
Código PHP:
Ver original
  1. <?php
  2. /* Execute a prepared statement by binding PHP variables */
  3. $sth = $dbh->prepare('SELECT name, colour, calories
  4.    FROM fruit
  5.    WHERE calories < :calories AND colour = :colour');
  6. $sth->bindParam(':calories', $_GET['calorias'], PDO::PARAM_INT);
  7. $sth->bindParam(':colour', $_GET['color'], PDO::PARAM_STR, 12);
  8. $sth->execute();
  9. // Imprimir el resultado.
  10. print_r($sth->fetchAll());
  11. ?>

Forma 3 (bindValue)
Código PHP:
Ver original
  1. <?php
  2. /* Execute a prepared statement by binding PHP variables */
  3. $sth = $dbh->prepare('SELECT name, colour, calories
  4.    FROM fruit
  5.    WHERE calories < :calories AND colour = :colour');
  6. $sth->bindValue(':calories', $_GET['calorias'], PDO::PARAM_INT);
  7. $sth->bindValue(':colour', $_GET['color'], PDO::PARAM_STR);
  8. $sth->execute();
  9. // Imprimir el resultado.
  10. print_r($sth->fetchAll());
  11. ?>

Aclarando que $_GET['calorias'] y $_GET['color'] son recogidas de un formulario sin mas.