PHP的DES加解密函数 与JAVA兼容

来源:互联网 发布:java杨辉三角输出空格 编辑:程序博客网 时间:2024/05/16 12:47

PHP可以使用mcrypt_encrypt进行DES加密与解密,但实际上操作,你会发现它与JAVA的DES加密出来的字符串,有些不同。基本上是前半段一样,后半段不一样。找到PHP官方网站上对这个函数的文档,有人回复了,并给出了代码。经测,这样加密解密就跟JAVA中的兼容了。

If you want to be interoperable with other PKCS  #7 padding implementations, like the Legion of the Bouncy Castle Java  cryptography APIs, you should always pad, that is a 8-byte (block size)  padding should be added, even if not necessary

PHP 代码复制内容到剪贴板
        
  1. <?php      
  2.       
  3. function encrypt($str$key)      
  4. {      
  5.     $block = mcrypt_get_block_size('des''ecb');      
  6.     $pad = $block - (strlen($str) % $block);      
  7.     $str .= str_repeat(chr($pad), $pad);      
  8.       
  9.     return mcrypt_encrypt(MCRYPT_DES, $key$str, MCRYPT_MODE_ECB);      
  10. }      
  11.       
  12. function decrypt($str$key)      
  13. {        
  14.     $str = mcrypt_decrypt(MCRYPT_DES, $key$str, MCRYPT_MODE_ECB);      
  15.       
  16.     $block = mcrypt_get_block_size('des''ecb');      
  17.     $pad = ord($str[($len = strlen($str)) - 1]);      
  18.     return substr($str, 0, strlen($str) - $pad);      
  19. }      
  20.       
  21. ?>  
0 0