Ver Mensaje Individual
  #3 (permalink)  
Antiguo 13/04/2015, 09:58
Avatar de Thejuanjo
Thejuanjo
 
Fecha de Ingreso: mayo-2014
Mensajes: 28
Antigüedad: 10 años
Puntos: 2
Sonrisa Respuesta: Encriptar un link

Si lo que quieres es hacer una URL tipo de recuperación de contraseñas, lo que tienes que hacer es, en la base de datos donde tienes alojada la información de los usuarios (supongo que tendrás una tabla o más dedicada a ello), añadir una columna nueva con una función de Únique, y que sea varchar, o text, segun la longitud de la url que desees.

Creamos un código aleatoriamente.

Código PHP:
Ver original
  1. <?php
  2.  
  3. //Coneccion a la base de datos
  4. //127.0.0.1 = localhost
  5. $serveradress = "127.0.0.1";
  6. //Usuario por defecto = root
  7. $serveruser = "root";
  8. // contraseña por defecto = ascent
  9. $serverpass = "ascent";
  10.  
  11. $connect = new mysqli($serveradress, $serveruser, $serverpass);
  12.  
  13. $user_selected = mysqli_query($connect, "SELECT * FROM `base_de_datos`.`tabla` WHERE user = '".$name_user."' or id = '".$id_user."'") or die(mysqli_error());
  14. if(mysqli_num_rows($user_selected) > 0){while($raw = $user_selected ->fecth_array()){
  15. $id_user_select = $raw['id'];
  16. }}
  17.  
  18. function generarCodigo($longitud) {
  19.  $key = '';
  20.  $pattern = '1234567890abcdefghijklmnopqrstuvwxyz';
  21.  $max = strlen($pattern)-1;
  22.  for($i=0;$i < $longitud;$i++) $key .= $pattern{mt_rand(0,$max)};
  23.  return $key;
  24. }
  25.  
  26. //Ejemplo de uso
  27.  
  28. echo 'http://www.miweb.com?url='.generarCodigo(6).$id_user_select; // genera un código de 6 caracteres de longitud, con el último numero siendo igual a la id del usuario, así evitamos que exista un código identico.
  29. ?>

Ahora si insertamos la url, con este código podrás mostrar la información que desees al verificar la existencia de ese código, que será sustituido por otro inmediatamente dándole sólo un posible uso.
Código PHP:
Ver original
  1. <?php
  2. if(isset($_GET['url'])){$codigo = addslashed($_GET['url']);
  3.  
  4. $user_selected2 = mysqli_query($connect, "SELECT * FROM `base_de_datos`.`tabla` WHERE codigo = '".$codigo."'") or die(mysqli_error());
  5. if(mysqli_num_rows($user_selected2) > 0){while($raw2 = $user_selected2 ->fecth_array()){
  6. //entre {} coloca lo que quieres mostrar en tu web si el código usado es válido.
  7. echo 'código correcto!';
  8. //no tocar
  9. function generarCodigo($longitud) {
  10.  $key = '';
  11.  $pattern = '1234567890abcdefghijklmnopqrstuvwxyz';
  12.  $max = strlen($pattern)-1;
  13.  for($i=0;$i < $longitud;$i++) $key .= $pattern{mt_rand(0,$max)};
  14.  return $key;
  15. }
  16.  
  17. //Ejemplo de uso
  18.  
  19. $update = mysqli_query($connect, "UPDATE `base_de_datos`.`tabla` SET codigo = '".generarCodigo(6).$id_user_select."' WHERE codigo = '".$codigo."'");
  20. }}
  21.  
  22. }else{$codigo = 0; echo 'el código usado ha expirado o es incorrecto!';}
  23. ?>

PD: la respuesta la he elaborado con prisas, si encuentras un error por favor perdone las molestias, espero que le ayude.

Última edición por Thejuanjo; 14/04/2015 a las 09:59 Razón: PD, se me olvido poner que el codigo cambiara