Pour la plupart des cryptages de mots de passe, nous pouvons utiliser md5, sha1 et d'autres méthodes.
Peut empêcher efficacement les fuites de données, mais ces méthodes ne conviennent qu'au cryptage des données qui ne nécessite pas de restauration.
Pour les informations qui doivent être restaurées, un algorithme de cryptage et de décryptage réversible doit être utilisé.
De nombreux systèmes d'adhésion à des projets nécessitent une fonction de mémorisation de connexion. Lors de la mise en œuvre de la fonction via des cookiess, les informations client doivent être enregistrées directement dans les cookies. Si vous écrivez directement des cookies, cela entraînera inévitablement. sécurité dangers cachés, il est donc relativement sûr de l'enregistrer dans des cookies après cryptage réversible
Code source de la fonction
function encrypt($data, $key) { $prep_code = serialize($data); $block = mcrypt_get_block_size('des', 'ecb'); if (($pad = $block - (strlen($prep_code) % $block)) < $block) { $prep_code .= str_repeat(chr($pad), $pad); } $encrypt = mcrypt_encrypt(MCRYPT_DES, $key, $prep_code, MCRYPT_MODE_ECB); return base64_encode($encrypt); } function decrypt($str, $key) { $str = base64_decode($str); $str = mcrypt_decrypt(MCRYPT_DES, $key, $str, MCRYPT_MODE_ECB); $block = mcrypt_get_block_size('des', 'ecb'); $pad = ord($str[($len = strlen($str)) - 1]); if ($pad && $pad < $block && preg_match('/' . chr($pad) . '{' . $pad . '}$/', $str)) { $str = substr($str, 0, strlen($str) - $pad); } return unserialize($str); }
Fonction d'appel
$key = 'okyo.cn'; $data = array('id' => 100, 'username' => 'customer', 'password' => 'e10adc3949ba59abbe56e057f20f883e'); $snarr = serialize($data); $en = encrypt($data, $key); $de = decrypt($en, $key); echo "加密原型:"; print_r($data); echo " 密钥:$key 加密结果:$en 解密结果:"; print_r($de);
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!