Foros del Web » Programando para Internet » PHP »

Problema al actualizar datos de la base de datos

Estas en el tema de Problema al actualizar datos de la base de datos en el foro de PHP en Foros del Web. Hola tengo un problema al actualizar un dato en la base de datos en este caso es una contraseña justamente es para que cambiar la ...
  #1 (permalink)  
Antiguo 10/04/2016, 19:31
 
Fecha de Ingreso: abril-2016
Mensajes: 7
Antigüedad: 8 años, 1 mes
Puntos: 0
Problema al actualizar datos de la base de datos

Hola tengo un problema al actualizar un dato en la base de datos en este caso es una contraseña justamente es para que cambiar la contraseña de un registro

este es el codigo de php (aviso mi forma de programar es media rara y ya se lo del tema de las variables y la seguridad por ahora es para empezar )
Código PHP:
Ver original
  1. <?php
  2. $pass = $_POST['pass1'];
  3. $npass = $_POST['pass'];
  4. $email = $_POST['email1'];
  5.  
  6. $password = sha1($npass);
  7. if ($email = $email1)
  8. {
  9. $conexion = mysqli_connect("","","","") or die('Error al Conectar con la base de datos');
  10.  
  11. $result = mysqli_query($conexion, "SELECT `id` FROM `wisher` WHERE `email` = '".$email."' AND `password` = '".$pass."'");
  12. if(mysqli_num_rows($result) != 0)
  13. {
  14.  
  15. header("Location: indexus.php?error=error");
  16.  
  17. }
  18. else if ($pass != $npass)
  19.  
  20. {
  21.  
  22. $conexion = mysqli_connect("mysql.hostinger.com.ar","","","") or die("Error al conectar");
  23.  
  24. $datos = "UPDATE `wisher`(`password`) SET `password`='$password'  where password='$pass'";
  25. }
  26.  
  27. if(mysqli_query($conexion,$datos)){
  28. header("Location: login.php");
  29.  
  30.  
  31. }
  32.  
  33. else{
  34. header("Location: indexus.php?error=error");
  35. }
  36.  
  37.  
  38. mysqli_close($conexion);
  39. ?>
lo que esta borrado de la conexion lo borre por tema de seguridad
  #2 (permalink)  
Antiguo 10/04/2016, 20:45
Avatar de xfxstudios  
Fecha de Ingreso: junio-2015
Ubicación: Valencia - Venezuela
Mensajes: 2.448
Antigüedad: 8 años, 10 meses
Puntos: 263
Respuesta: Problema al actualizar datos de la base de datos

?????????????????????
Código PHP:
Ver original
  1. $email = $_POST['email1'];<<<<<<<<<<<<<<<<
  2.  
  3. if ($email = $email1)<<<<<<<<<<<<<<<<<<<<

de donde sale $email1???

Segundo: Aqui solo estas seleccionando la id y no la password que quieres actualizar, se podria analizar mejor

Tercero:
Aqui indicas que debes actualizar si la pass no coincide con el npass

Código PHP:
Ver original
  1. }
  2. else if ($pass != $npass)
  3.  
  4. {
  5.  
  6. $conexion = mysqli_connect("mysql.hostinger.com.ar","","","") or die("Error al conectar");
  7.  
  8. $datos = "UPDATE `wisher`(`password`) SET `password`='$password'  where password='$pass'";
  9. }


como sería eso???? es decir, que si yo envío las claves deferentes me la actualiza y si envio las claves que coincidan no??, debería de ser indiferente, lo que deberias de comparar es la clave anterior con la almacenada en la base para así verificar y permitir en consecuencia la actualización o no.
__________________
[email protected]
HITCEL
  #3 (permalink)  
Antiguo 10/04/2016, 21:19
 
Fecha de Ingreso: diciembre-2015
Mensajes: 529
Antigüedad: 8 años, 4 meses
Puntos: 39
Respuesta: Problema al actualizar datos de la base de datos

Código SQL:
Ver original
  1. UPDATE `wisher`(`password`) SET `password`='$password'  WHERE password='$pass'

Estás seguro que la consulta es correcta? Pruebala en tu SMBD y nos dices. Aquí una referencia: aquí

Etiquetas: mysql, registro, select, sql, variable
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 07:53.