Se está poniendo de moda GOST (así, sin H, que no es inglés) desde todo el asunto Snowden porque, según han empezado a decir algunos expertos en seguridad, es uno de los algoritmos que la NSA no ha logrado romper (al menos no se sospecha que lo lograran). Se trata de un algoritmo criptográfico parido por matemáticos soviéticos en los últimos años de la Guerra Fría, revisado posteriormente un par de ocasiones. Para más info, como siempre, la wikipedia.
El caso es que con el tema de la paranoia de la seguridad me han pedido una función para encriptar passwords segura en PHP, aunque en PHP 5.5 ya tengamos unas muy cómoda y seguras funciones para trabajar con passwords. Pero cliente manda, y ha leído que GOST tralarí y no se fía de algo que sea standar… así que me he hecho una función propia, que os comparto por si queréis usarla.
<? function getSecurePass($password_plano, $username){ if(strlen($password_plano)<8){ //exigimos un mínimo de 8 caracteres $response = array("aceptado"=>FALSE, "Resultado"=>"Error: Contraseña demasiado corta"); }else{ if(strlen($password_plano) % 2){ $salt0="@fr!87$"; //aquí metemos una cadena, la que vosotros prefiráis }else{ $salt0="~m¿0kL" //aquí metemos otra, y según sea par o impar la longitud cogerá la que corresponda } $salt1 = substr($password_plano, strlen($texto_plano)-6, 5); $salt2 = substr(md5($username), 6, 6); $salt3 = substr($username, strlen($username),-2); $arrayPss = str_split($password_plano,(strlen($password_plano)/2)+1); $hash = hash('gost', $salt3.$arrayPss[0].$salt0.$salt1.$arrayPss[1].$salt3.$salt2); sleep(1); $response = array("aceptado"=>True, "Resultado"=>$hash); } reutrn $response; } ?>
Y para complementar el sistema de login contra ataques por fuerza bruta es una buena idea ralentizar la respuesta desde el servidor. ¿Y cómo hacerlo sin darle la vara al usuario mucho? Haciendo una función de login que espere, pero sólo cuando el password sea erróneo. En este caso no desarrollé nada y copié un ejemplo desde php.net que ahí os pego (en mi caso lo adapté para usarlo con el resto del sistema de login desarrollado, en los comentarios del enlace está la función original son su explicación):
<?php public function handle_login() { if($uid = user::check_password($_REQUEST['email'], $_REQUEST['password'])) { return self::authenticate_user($uid); } else { // delay failed output by 2 seconds // to prevent bruit force attacks sleep(2); return self::login_failed(); } } ?>
Espero que os sirva de ayuda a la hora de asegurar vuestras contraseñas.
¿$password_plano = $texto_plano?
Desliz mío, que cambié el nombre de las variables y no me fijé. Gracias. Lo corrijo.
Disculpa por la pregunta, pero de donde viene esta variable?
‘$texto_plano’
Muchas gracias
Gracias por el aviso, creí que había corregido eso tras el anterior comentario donde ya lo comentaban… debí editar y finalmente no salvar. Ahora lo corrijo.
Por nada, tu script me sirvio de mucho.
Saludos desde Peru.