Foros del Web » Programando para Internet » PHP »

problema con addslashes

Estas en el tema de problema con addslashes en el foro de PHP en Foros del Web. Buenas noches, Me ocurre algo que creo va a ser algo absurdo... He usado otras veces addslashes() y nunca me dió problema, pero no entiendo ...
  #1 (permalink)  
Antiguo 10/05/2013, 14:52
 
Fecha de Ingreso: octubre-2010
Ubicación: Costa Brava
Mensajes: 58
Antigüedad: 13 años, 6 meses
Puntos: 2
Pregunta problema con addslashes

Buenas noches,

Me ocurre algo que creo va a ser algo absurdo... He usado otras veces addslashes() y nunca me dió problema, pero no entiendo qué pasa.

En mi formulario tengo varios campos texto, cuando los voy a entrar en la BD lo hago así:
Código PHP:
$SQL_pl="UPDATE pl_cl SET pl_nm='".addslashes($nom)."', pl_nm2='".addslashes($nom2)."',pl_desc='".addslashes($pl_desc)."', pl_hist='".addslashes($pl_hist)."', sr_id='".$sr."', fn_id='".$fn."', en_id='".$en."'; 
y el error es el siguiente:
Warning: pg_exec(): Query failed: ERROR: error de sintaxis en o cerca de «on» LINE 1: ...És una platja urbna ben dotada de serveis, des d\'on podem e... ^ in..

Como podéis ver, la barra se coloca, pero falla igual.

Alguien ve algo o sabe porqué puede pasar?

Muchas gracias!
  #2 (permalink)  
Antiguo 10/05/2013, 15:01
Avatar de pateketrueke
Modernizr
 
Fecha de Ingreso: abril-2008
Ubicación: Mexihco-Tenochtitlan
Mensajes: 26.399
Antigüedad: 16 años
Puntos: 2534
Respuesta: problema con addslashes

El motor de postgres no utiliza la barra invertida como escape sino doble comilla, el error consiste en que no usas la función adecuada para escapar, addslashes() sirve en ocasiones pero nunca será la mejor solución.

La función pg_escape_string() es lo que necesitas, consulta el manual.
__________________
Y U NO RTFM? щ(ºдºщ)

No atiendo por MP nada que no sea personal.

Etiquetas: addslashes, formulario, 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 06:31.