DES signifie Data Encryption Standard, qui est un algorithme de bloc qui utilise le cryptage par clé. En 1977, il a été déterminé comme la norme fédérale de traitement de l'information (FIPS) par le Bureau national des normes du gouvernement fédéral américain et autorisé en Afrique. Utilisé dans les communications gouvernementales classifiées, l’algorithme a ensuite été largement diffusé à l’échelle internationale. Il convient de noter que dans certaines publications, le DES en tant qu'algorithme est appelé algorithme de chiffrement de données (DEA), qui a été distingué du DES en tant que standard.
Cet article présente principalement la méthode de cryptage et de décryptage DES implémentée par PHP, et analyse les techniques associées de cryptage et de décryptage DES par PHP sous la forme d'un exemple complet. Les amis dans le besoin peuvent se référer à , les détails sont les suivants :
<?php $key = 'very important data'; function jiami($key, $str) { /* Open module, and create IV */ $td = mcrypt_module_open('des', '', 'ecb', ''); //$td = mcrypt_module_open(MCRYPT_DES, '', MCRYPT_MODE_CBC, ''); //$td = mcrypt_module_open('des', '', 'cbc', ''); $key = substr($key, 0, mcrypt_enc_get_key_size($td)); $iv_size = mcrypt_enc_get_iv_size($td); $iv = mcrypt_create_iv($iv_size, MCRYPT_RAND); /* Initialize encryption handle */ if (mcrypt_generic_init($td, $key, $iv) === -1) { return FALSE; } /* Encrypt data */ $c_t = mcrypt_generic($td, $str); /* Clean up */ mcrypt_generic_deinit($td); mcrypt_module_close($td); return $c_t; } function jiemi($key, $str) { /* Open module, and create IV */ $td = mcrypt_module_open('des', '', 'ecb', ''); //$td = mcrypt_module_open(MCRYPT_DES, '', MCRYPT_MODE_CBC, ''); //$td = mcrypt_module_open('des', '', 'cbc', ''); $key = substr($key, 0, mcrypt_enc_get_key_size($td)); $iv_size = mcrypt_enc_get_iv_size($td); $iv = mcrypt_create_iv($iv_size, MCRYPT_RAND); /* Initialize encryption handle */ if (mcrypt_generic_init($td, $key, $iv) === -1) { return FALSE; } /* Reinitialize buffers for decryption */ $p_t = mdecrypt_generic($td, $str); /* Clean up */ mcrypt_generic_deinit($td); mcrypt_module_close($td); return trim($p_t); } $str = 'hello world!'; echo 'key:' . $key . '<br>'; echo 'str:' . $str . '<br>'; $jiami = jiami($key, $str); echo '加密:' . $jiami . '<br>'; file_put_contents('jiamiqian.txt', $str); file_put_contents('jiamihou.txt', $jiami); $jiemi = jiemi($key, $jiami); echo '解密:' . $jiemi . '<br>';
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!