Foros del Web » Programando para Internet » PHP »

como evitar sql injection en php?

Estas en el tema de como evitar sql injection en php? en el foro de PHP en Foros del Web. Aunque parezca que el tema va en el foro de sql es aquí donde lo posteo porque sé más o menos como habría que hacer ...
  #1 (permalink)  
Antiguo 19/12/2011, 15:42
 
Fecha de Ingreso: febrero-2011
Mensajes: 78
Antigüedad: 13 años, 9 meses
Puntos: 0
como evitar sql injection en php?

Aunque parezca que el tema va en el foro de sql es aquí donde lo posteo porque sé más o menos como habría que hacer para evitar las sql injections: escapar las comillas simples poniendo \ delante de ellas. También hay funciones que lo hacen automáticamente
Cita:
$texto=mysql_escape_string($texto) //por ejemplo
. El problema es que cuando pinto la query me sale una consulta sql con las barras de escape delante y la base de datos no se la traga. Alguien me puede hechar un cable?
  #2 (permalink)  
Antiguo 19/12/2011, 15:55
 
Fecha de Ingreso: julio-2010
Mensajes: 393
Antigüedad: 14 años, 3 meses
Puntos: 67
Respuesta: como evitar sql injection en php?

usando mysql_escape_string está bien, y lo de las barras invertidas es normal, cuál es el problema? no termino de entender.
__________________
Páginas web de alta calidad y hechas a la medida.
  #3 (permalink)  
Antiguo 19/12/2011, 16:15
 
Fecha de Ingreso: febrero-2011
Mensajes: 78
Antigüedad: 13 años, 9 meses
Puntos: 0
Respuesta: como evitar sql injection en php?

Hago la query:
Cita:
$sql = "insert into wikiloc_idioma_fichas(id_ficha,id_idioma,titulo,de scripcion) Values ($id,44,'$titulo','$descripcion')";
Le paso la función que le mete los caracteres de escape:
Cita:
$sql = mysql_escape_string($sql);
La query me queda así:
Cita:
print_r($sql);
//apareceria la query así (id_ficha,id_idioma, descripcion) Values ($id,44,\'loquesea\',\'loquesea\')";
y al pasarlo a base de datos me da error:
Cita:
$resultado=mysql_query($sql);
  #4 (permalink)  
Antiguo 19/12/2011, 16:18
 
Fecha de Ingreso: julio-2010
Mensajes: 393
Antigüedad: 14 años, 3 meses
Puntos: 67
Respuesta: como evitar sql injection en php?

Problemas de concatenación intenta así:

Código PHP:
Ver original
  1. $sql = 'insert into wikiloc_idioma_fichas(id_ficha,id_idioma,titulo,de scripcion) Values ($id,44,' . $titulo . ', ' . $descripcion . ')';
__________________
Páginas web de alta calidad y hechas a la medida.
  #5 (permalink)  
Antiguo 19/12/2011, 16:36
 
Fecha de Ingreso: febrero-2011
Mensajes: 78
Antigüedad: 13 años, 9 meses
Puntos: 0
Respuesta: como evitar sql injection en php?

casi pero ahora me pinta esto:

Cita:
insert into wikiloc_idioma_fichas(id_ficha,id_idioma,titulo,de scripcion) Values (51363,44,Circular al macizo central (Picos de Europa) cerca de Los Llanos, Castilla y León (España),El tramo de la ruta del cares esta prohibido montar en bici)

es decir que ahora le faltan las comillas simples a los textos y por lo tanto me da un error de sintaxis.
Esta es la línea de código que te acabo de pintar:

Cita:
$sql = 'insert into wikiloc_idioma_fichas(id_ficha,id_idioma,titulo,de scripcion) Values (' . $id . ',44,' . $titulo . ',' . $descripcion . ')';
$sql=mysql_escape_string($sql);
  #6 (permalink)  
Antiguo 19/12/2011, 16:40
Avatar de pateketrueke
Modernizr
 
Fecha de Ingreso: abril-2008
Ubicación: Mexihco-Tenochtitlan
Mensajes: 26.399
Antigüedad: 16 años, 7 meses
Puntos: 2534
Respuesta: como evitar sql injection en php?

Si quieres aprender a manejar bien las comillas por tu cuenta te sugiero leer esto:
http://www.forosdelweb.com/f18/como-...s-bien-588701/

Se supone que las variables debes escaparlas individualmente antes de armar la consulta, y no escapar la consulta completa.
__________________
Y U NO RTFM? щ(ºдºщ)

No atiendo por MP nada que no sea personal.
  #7 (permalink)  
Antiguo 19/12/2011, 16:42
 
Fecha de Ingreso: julio-2010
Mensajes: 393
Antigüedad: 14 años, 3 meses
Puntos: 67
Respuesta: como evitar sql injection en php?

Perdón, fue por hacerlo rápido... ahora si...

Código PHP:
Ver original
  1. $sql = 'insert into wikiloc_idioma_fichas(id_ficha,id_idioma,titulo,de scripcion) Values ($id,44,\'' . $titulo . '\', \'' . $descripcion . '\')';

recuerda leer el link que te puso pateketrueke.

Un saludo!
__________________
Páginas web de alta calidad y hechas a la medida.
  #8 (permalink)  
Antiguo 19/12/2011, 16:49
 
Fecha de Ingreso: febrero-2011
Mensajes: 78
Antigüedad: 13 años, 9 meses
Puntos: 0
Respuesta: como evitar sql injection en php?

Gracias a los dos, sois unos cracks!

Etiquetas: injection, sql
Atención: Estás leyendo un tema que no tiene actividad desde hace más de 6 MESES, te recomendamos abrir un Nuevo tema en lugar de responder al actual.
Respuesta




La zona horaria es GMT -6. Ahora son las 16:25.