DES CBC模式加密算法php与java互通
在工作中因为一些原因导致DES CBC加密在php和java上无法相互加解密导致无法互通。经过网上的查找一些资料后,可以实现相互加解密。记录下,以免忘记。实测可以实现相互加解密。
PHP 部分代码:
<?php class DES { var $key; var $iv; //偏移量 function DES($key,$iv=0) { $this->key = $key; if($iv == 0) { $this->iv = $key; } else { $this->iv = $iv; } } //加密 function encrypt($str) { $size = mcrypt_get_block_size ( MCRYPT_DES, MCRYPT_MODE_CBC ); $str = $this->Pkcs5Pad ( $str, $size ); ///$data=mcrypt_cbc(MCRYPT_DES, $this->key, $str, MCRYPT_ENCRYPT, $this->iv); $data = mcrypt_encrypt(MCRYPT_DES,$this->key, $str, "cbc", $this->iv); return base64_encode($data); } //解密 function decrypt($str) { $str = base64_decode ($str); $str = mcrypt_decrypt(MCRYPT_DES, $this->key, $str, "cbc", $this->iv ); $str = $this->pkcs5Unpad( $str ); return $str; } function hex2bin($hexData) { $binData = ""; for($i = 0; $i < strlen ( $hexData ); $i += 2) { $binData .= chr(hexdec(substr($hexData, $i, 2))); } return $binData; } function pkcs5Pad($text, $blocksize) { $pad = $blocksize - (strlen ( $text ) % $blocksize); return $text . str_repeat ( chr ( $pad ), $pad ); } function pkcs5Unpad($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 = "{"userid":"100000","action":"get_user_detail"}"; $key="12312345"; $crypt = new DES($key); $mstr = $crypt->encrypt($str); $str = $crypt->decrypt($mstr); echo $mstr." <=> ".$str; ?>
声明:该文观点仅代表作者本人,牛骨文系教育信息发布平台,牛骨文仅提供信息存储空间服务。
- 上一篇: Linux中查看各文件夹大小命令du -h --max-depth=1
- 下一篇: js 获取表单数据
copyright © 2008-2019 亿联网络 版权所有 备案号:粤ICP备14031511号-2