java/php DES/CBC/PKCS5Padding加密解密算法实现过程

先看java代码

Java代码  

  1. public static String encrypt(String message, String key) throws Exception {

  2. Cipher cipher = Cipher.getInstance("DES/CBC/PKCS5Padding");
  3. DESKeySpec desKeySpec = new DESKeySpec(key.getBytes("UTF-8"));
  4. SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DES");

  5. SecretKey secretKey = keyFactory.generateSecret(desKeySpec);

  6. IvParameterSpec iv = new IvParameterSpec(key.getBytes("UTF-8"));

  7. cipher.init(Cipher.ENCRYPT_MODE, secretKey, iv);
  8. return toHexString(cipher.doFinal(message.getBytes("UTF-8")));

  9. }
  10. public static String decrypt(String message, String key) throws Exception {
  11. byte[] bytesrc = convertHexString(message);

  12. Cipher cipher = Cipher.getInstance("DES/CBC/PKCS5Padding");

  13. DESKeySpec desKeySpec = new DESKeySpec(key.getBytes("UTF-8"));

  14. SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DES");

  15. SecretKey secretKey = keyFactory.generateSecret(desKeySpec);

  16. IvParameterSpec iv = new IvParameterSpec(key.getBytes("UTF-8"));
  17. cipher.init(Cipher.DECRYPT_MODE, secretKey, iv);
  18. byte[] retByte = cipher.doFinal(bytesrc);

  19. return new String(retByte);

  20. }
  21. public static byte[] convertHexString(String ss) {

  22. byte digest[] = new byte[ss.length() / 2];

  23. for (int i = 0; i < digest.length; i++) {

  24. String byteString = ss.substring(2 * i, 2 * i + 2);

  25. int byteValue = Integer.parseInt(byteString, 16);

  26. digest[i] = (byte) byteValue;

  27. }
  28. return digest;

  29. }

  30. public static String toHexString(byte b[]) {

  31. StringBuffer hexString = new StringBuffer();

  32. for (int i = 0; i < b.length; i++) {

  33. String plainText = Integer.toHexString(0xff & b[i]);

  34. if (plainText.length() < 2)

  35. plainText = "0" + plainText;

  36. hexString.append(plainText);

  37. }
  38. return hexString.toString();

  39. }

java写的已经很明显使用的是CBC/PKCS补码方式 

在看PHP

Php代码  

  1. function encrypt($str) {

  2. //加密,返回大写十六进制字符串

  3. $size = mcrypt_get_block_size (MCRYPT_DES, MCRYPT_MODE_[color=red]CBC[/color] );

  4. $str = $this->pkcs5Pad ( $str, $size );

  5. return strtoupper( bin2hex( mcrypt_cbc(MCRYPT_DES, $this->key, $str, MCRYPT_ENCRYPT, $this->iv ) ) );

  6. }
  7. function decrypt($str) {

  8. //解密

  9. $strBin = $this->hex2bin( strtolower( $str ) );

  10. $str = mcrypt_cbc( MCRYPT_DES, $this->key, $strBin, MCRYPT_DECRYPT, $this->iv );

  11. $str = $this->pkcs5Unpad( $str );
  12. return $str;

  13. }

  14. function hex2bin($hexData) {

  15. $binData = "";

  16. for($i = 0; $i  < strlen ( $hexData ); $i += 2) {

  17. $binData .= chr ( hexdec ( substr ( $hexData, $i, 2 ) ) );

  18. }

  19. return $binData;

  20. }
  21. function pkcs5Pad($text, $blocksize) {

  22. $pad = $blocksize - (strlen ( $text ) % $blocksize);

  23. return $text . str_repeat ( chr ( $pad ), $pad );

  24. }
  25. function pkcs5Unpad($text) {

  26. $pad = ord ( $text {strlen ( $text ) - 1} );

  27. if ($pad > strlen ( $text )) return false;
  28. if (strspn ( $text, chr ( $pad ), strlen ( $text ) - $pad ) != $pad)   return false;
  29. return substr ( $text, 0, - 1 * $pad );

  30. }

java/php DES/CBC/PKCS5Padding加密解密算法实现过程

时间: 2024-10-10 22:16:27

java/php DES/CBC/PKCS5Padding加密解密算法实现过程的相关文章

java实现AES/CBC/pack5padding加解密算法

最近要测试一个借口,借口的传值参数是使用AES加密,偏移量为0000000000000000,秘钥:12345678901234567890123456789012,加密后内容转成16进制发送,用网上的代码一直没实现,最后发送是因为jre的两个jar包需要升级,支持key大于16位. 两个jar包:US_export_policy.jar.local_policy.jar,下载地址:https://files.cnblogs.com/files/tech-test/security.zip 代码

php实现AES/CBC/PKCS5Padding加密解密

<?php class MagicCrypt { private $iv = "0102030405060708";//密钥偏移量IV private $encryptKey = "58e15e87488a47c9";//AESkey //加密 public function encrypt($encryptStr) { $localIV = $this->iv; $encryptKey = $this->encryptKey; //Open mo

OC的DES加密,使与java的Cipher类用DES/CBC/PKCS5Padding方式的加密结果相同

问题说明: 最近用到DES加密,并且要与java的Cipher类加密的结果保持一致.没研究过java的Cliper,但工作中Cipher根据DES/CBC/PKCS5Padding加密方式生成了一个字符串.比较后发现,此字符串与将OC加密生成的NSData直接用字符串格式化([NSString stringWithFormat:@"%@",data])相同.所以就先这么用了. 代码如下: #import "CommonCrypto/CommonCryptor.h"

OC的DES加密,使与java的Cipher类用DES/CBC/PKCS5Padding方式的加密结果同样

问题说明: 近期用到DES加密,而且要与java的Cipher类加密的结果保持一致.没研究过java的Cliper,但工作中Cipher依据DES/CBC/PKCS5Padding加密方式生成了一个字符串. 比較后发现,此字符串与将OC加密生成的NSData直接用字符串格式化([NSString stringWithFormat:@"%@",data])同样.所以就先这么用了. 代码例如以下: #import "CommonCrypto/CommonCryptor.h&quo

Java DES 加解密(&quot;DES/CBC/PKCS5Padding&quot;)

/** * DES加密 * * @param data 加密数据 * @param key 密钥 * @return 返回加密后的数据 */ public static byte[] desEncrypt(byte[] data, String key, String charset) { try { Cipher cipher = Cipher.getInstance("DES/CBC/PKCS5Padding"); byte[] k = charset == null || cha

java 实现 DES加密 解密算法

DES算法的入口参数有三个:Key.Data.Mode.其中Key为8个字节共64位,是DES算法的工作密钥:Data也为8个字节64位,是要被加密或被解密的数据:Mode为DES的工作方式,有两种:加密或解密.  DES算法是这样工作的:如Mode为加密,则用Key 去把数据Data进行加密, 生成Data的密码形式(64位)作为DES的输出结果:如 Mode为解密,则用Key去把密码形式的数据Data解密,还原为Data的明码形式(64位)作为DES的输出结果.在通信网络的两端,双方约定一致

用JAVA实现的DES加密解密算法

package Encrypt; import java.security.*; import javax.crypto.*; import sun.misc.*; /** * 使用DES加密与解密,可对byte[],String类型进行加密与解密 * 密文可使用String,byte[]存储. * 方法: * void getKey(String strKey)从strKey的字条生成一个Key * String getEncString(String strMing)对strMing进行加密

DES加密 java与.net可以相互加密解密两种方法

方法一:通过.NET的key和VI来生成对应于java的key java: import java.security.Key; import java.security.spec.AlgorithmParameterSpec; import javax.crypto.Cipher; import javax.crypto.SecretKeyFactory; import javax.crypto.spec.DESKeySpec; import javax.crypto.spec.IvParame

php与java通用AES加密解密算法

php与java通用AES加密解密算法 AES指高级加密标准(Advanced Encryption Standard),是当前最流行的一种密码算法,在web应用开发,特别是对外提供接口时经常会用到,下面是我整理的一套php与java通用的AES加密解密算法. php版代码如下: <?php class CryptAES { protected $cipher = MCRYPT_RIJNDAEL_128; protected $mode = MCRYPT_MODE_ECB; protected