Foros del Web » Programando para Internet » PHP »

[SOLUCIONADO] mysql_real_escape_string no funciona

Estas en el tema de mysql_real_escape_string no funciona en el foro de PHP en Foros del Web. Saludos gente, tengo una consulta con respecto a esta funcion de php. para prueba tengo esto en una funcion @import url("http://static.forosdelweb.com/clientscript/vbulletin_css/geshi.css"); Código PHP: Ver original ...
  #1 (permalink)  
Antiguo 18/01/2013, 14:15
Avatar de BloodShadow  
Fecha de Ingreso: marzo-2010
Ubicación: El Salvador
Mensajes: 393
Antigüedad: 14 años
Puntos: 52
Pregunta mysql_real_escape_string no funciona

Saludos gente, tengo una consulta con respecto a esta funcion de php.

para prueba tengo esto en una funcion

Código PHP:
Ver original
  1. public static function login($user, $password){
  2.         echo '<br/>USER ANTES1: ' . $user;
  3.         echo '<br/>PASS ANTES: ' . $password;
  4.         $user_safe = mysql_real_escape_string($user);
  5.         $password_safe = mysql_real_escape_string($password);
  6.         echo '<br/>USER SAFE ANTES: ' . $user_safe;
  7.         echo '<br/>PASS SAFE ANTES: ' . $password_safe;
  8.         $query = 'SELECT IFNULL(`id`, 0) FROM `user` WHERE `user` = \'' . $user_safe . '\' AND `password` = \'' . $password_safe . '\' AND `active` = 1 LIMIT 0,1';
  9.         echo '<br/>'.$query;
  10.         exit();
  11.         $rs = kconnection::getResultData($query);
  12.         return $rs;
  13.     }

y el resultado en pantalla es:

USER ANTES1: [email protected]
PASS ANTES: 123456
USER SAFE ANTES:
PASS SAFE ANTES:
SELECT IFNULL(`id`, 0) FROM `user` WHERE `user` = '' AND `password` = '' AND `active` = 1 LIMIT 0,1

Esto me pasa solo cuando lo subo al servidor, en mi local funciona perfectamente y no entiendo el xq, la version de php local es 5.3.1 y en el server es 5.3.2 segun la documentacion de php esta funcion esta obsoleta a partir de php 5.5+ cosa q no se cumple en mi caso, alguien me podria explicar que sucede?
  #2 (permalink)  
Antiguo 18/01/2013, 14:20
Avatar de pateketrueke
Modernizr
 
Fecha de Ingreso: abril-2008
Ubicación: Mexihco-Tenochtitlan
Mensajes: 26.399
Antigüedad: 16 años
Puntos: 2534
Respuesta: mysql_real_escape_string no funciona

Es probable que falte el segundo argumento de conexión, que en la mayoría de los casos se trata de suponer pero para tu caso debes especificarlo en producción pues PHP no lo puede determinar automáticamente.
__________________
Y U NO RTFM? щ(ºдºщ)

No atiendo por MP nada que no sea personal.
  #3 (permalink)  
Antiguo 18/01/2013, 14:39
Avatar de BloodShadow  
Fecha de Ingreso: marzo-2010
Ubicación: El Salvador
Mensajes: 393
Antigüedad: 14 años
Puntos: 52
Respuesta: mysql_real_escape_string no funciona

Cita:
Iniciado por pateketrueke Ver Mensaje
Es probable que falte el segundo argumento de conexión, que en la mayoría de los casos se trata de suponer pero para tu caso debes especificarlo en producción pues PHP no lo puede determinar automáticamente.
Lo del parametro no se como pasarlo, si en realidad aun no hago la consulta hasta q me conecto con la clase de mi conexion.

Cita:
Iniciado por pateketrueke Ver Mensaje
debes especificarlo en producción pues PHP no lo puede determinar automáticamente.
Esto no te lo entiendo muy bien.
  #4 (permalink)  
Antiguo 18/01/2013, 14:43
Avatar de pateketrueke
Modernizr
 
Fecha de Ingreso: abril-2008
Ubicación: Mexihco-Tenochtitlan
Mensajes: 26.399
Antigüedad: 16 años
Puntos: 2534
Respuesta: mysql_real_escape_string no funciona

Si, como dices que en local funciona es porque PHP intenta determinar la conexión como dicen en el manual.

En tu sitio de producción (el hosting pues) la configuración de conexión debe ser distinta, por ende PHP no la puede deducir, entonces debes especificar el argumento como dice el manual.

Necesitas abrir la conexión para poder usarla, sólo eso.
__________________
Y U NO RTFM? щ(ºдºщ)

No atiendo por MP nada que no sea personal.
  #5 (permalink)  
Antiguo 18/01/2013, 15:35
Avatar de BloodShadow  
Fecha de Ingreso: marzo-2010
Ubicación: El Salvador
Mensajes: 393
Antigüedad: 14 años
Puntos: 52
Respuesta: mysql_real_escape_string no funciona

gracias amigo @pateketrueke al final hice lo q me dijiste y funciono todo, tenia un metodo para abrir la conexion asi q ese use =D: gracias!!!

Código PHP:
Ver original
  1. public static function login($user, $password){
  2.         $conn = kconnection::open() ;
  3.         $user_safe = mysql_real_escape_string($user);
  4.         $password_safe = mysql_real_escape_string($password);
  5.         $query = 'SELECT IFNULL(`id`, 0) FROM `user` WHERE `user` = \'' . $user_safe . '\' AND `password` = \'' . $password_safe . '\' AND `active` = 1 LIMIT 0,1';
  6.        
  7.         $rs = kconnection::getResultData($query);
  8.         return $rs;
  9.     }
  #6 (permalink)  
Antiguo 07/03/2014, 04:27
 
Fecha de Ingreso: mayo-2010
Mensajes: 7
Antigüedad: 13 años, 10 meses
Puntos: 0
Respuesta: mysql_real_escape_string no funciona

Cita:
Iniciado por BloodShadow Ver Mensaje
Saludos gente, tengo una consulta con respecto a esta funcion de php.

para prueba tengo esto en una funcion

Código PHP:
Ver original
  1. public static function login($user, $password){
  2.         echo '<br/>USER ANTES1: ' . $user;
  3.         echo '<br/>PASS ANTES: ' . $password;
  4.         $user_safe = mysql_real_escape_string($user);
  5.         $password_safe = mysql_real_escape_string($password);
  6.         echo '<br/>USER SAFE ANTES: ' . $user_safe;
  7.         echo '<br/>PASS SAFE ANTES: ' . $password_safe;
  8.         $query = 'SELECT IFNULL(`id`, 0) FROM `user` WHERE `user` = \'' . $user_safe . '\' AND `password` = \'' . $password_safe . '\' AND `active` = 1 LIMIT 0,1';
  9.         echo '<br/>'.$query;
  10.         exit();
  11.         $rs = kconnection::getResultData($query);
  12.         return $rs;
  13.     }

y el resultado en pantalla es:

USER ANTES1: [email][email protected][/email]
PASS ANTES: 123456
USER SAFE ANTES:
PASS SAFE ANTES:

SELECT IFNULL(`id`, 0) FROM `user` WHERE `user` = '' AND `password` = '' AND `active` = 1 LIMIT 0,1

Esto me pasa solo cuando lo subo al servidor, en mi local funciona perfectamente y no entiendo el xq, la version de php local es 5.3.1 y en el server es 5.3.2 segun la [URL="http://php.net/manual/es/function.mysql-real-escape-string.php"]documentacion de php[/URL] esta funcion esta obsoleta a partir de php 5.5+ cosa q no se cumple en mi caso, alguien me podria explicar que sucede?

Eso mismo me pasaba...me volvi loco!!!

Dejo mi solucion, espero a alguien mas le sirva

Donde tenia(usando mysqli_real_escape_string):
$user_safe = mysqli_real_escape_string($user);

he colocado

$user_safe = mysqli_real_escape_string($link,$user);

En localhost (PHP version 5.5) funcionaba de maravillas con la primera opcion, pero hosteado en 000webhost, no funcionaba (PHP version 5.2.*).

Etiquetas: funcion
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 20:48.