PHP的des加密+ ECB方式+PKCS5 补齐
程序员文章站
2022-06-02 21:17:07
...
PHP的des加密+ ECB模式+PKCS5 补齐
/** * * 加密函数 * 算法:des * 加密模式:ecb * 补齐方法:PKCS5 * * @param unknown_type $input */ function encryptDesEcbPKCS5($input, $key) { $size = mcrypt_get_block_size('des', 'ecb'); $input = pkcs5_pad($input, $size); $td = mcrypt_module_open('des', '', 'ecb', ''); //$iv = mcrypt_create_iv (mcrypt_enc_get_iv_size($td), MCRYPT_RAND); $iv = 0; mcrypt_generic_init($td, $key, $iv); $data = mdecrypt_generic ($td, $input); mcrypt_generic_deinit($td); mcrypt_module_close($td); //$data = base64_encode($data); return $data; } /** * 解密函数 * 算法:des * 加密模式:ecb * 补齐方法:PKCS5 * @param unknown_type $input */ function decryptDesEcbPKCS5($input, $key) { $size = mcrypt_get_block_size('des', 'ecb'); $td = mcrypt_module_open('des', '', 'ecb', ''); $iv = 0; mcrypt_generic_init($td, $key, $iv); $data = mcrypt_generic($td, $input); mcrypt_generic_deinit($td); mcrypt_module_close($td); $data = pkcs5_unpad($data, $size); //$data = base64_encode($data); return $data; } function pkcs5_pad ($text, $blocksize) { $pad = $blocksize - (strlen($text) % $blocksize); return $text . str_repeat(chr($pad), $pad); } function pkcs5_unpad($text) { $pad = ord($text{strlen($text) - 1}); if ($pad > strlen($text)) return false; if (strspn($text, chr($pad), strlen($text) - $pad) != $pad) return false; return substr($text, 0, -1 * $pad); } $str = 'test crypt'; $key = 'jack11'; $res = encryptDesEcbPKCS5($str, $key); echo "$res\n"; $deRes = decryptDesEcbPKCS5($res, $key); echo "\n$deRes\n";
?
PHP的DES加密的补齐比较特殊,而且不能指定
http://www.herongyang.com/Cryptography/DES-PHP-Block-Padding-in-mcrypt.html
相关文章
相关视频
专题推荐
-
独孤九贱-php全栈开发教程
全栈 170W+
主讲:Peter-Zhu 轻松幽默、简短易学,非常适合PHP学习入门
-
玉女心经-web前端开发教程
入门 80W+
主讲:灭绝师太 由浅入深、明快简洁,非常适合前端学习入门
-
天龙八部-实战开发教程
实战 120W+
主讲:西门大官人 思路清晰、严谨规范,适合有一定web编程基础学习
推荐阅读
-
PHP7实现和CryptoJS的AES加密方式互通示例【AES-128-ECB加密】
-
PHP的des加密+ ECB模式+PKCS5 补齐
-
PHP的des加密+ ECB模式+PKCS5 补齐
-
PHP的des加密+ ECB方式+PKCS5 补齐
-
PHP的des加密+ ECB方式+PKCS5 补齐
-
PHP的des加密+ ECB方式+PKCS5 补齐
-
PHP7实现和CryptoJS的AES加密方式互通示例【AES-128-ECB加密】
-
PHP对接java的AES/ECB/PKCS5Padding加密方式的示例代码(图)
-
PHP对接java的AES/ECB/PKCS5Padding加密方式的示例代码(图)
网友评论
文明上网理性发言,请遵守 新闻评论服务协议
我要评论