首页 新闻 会员 周边

C#和JAVA AES加密解密遇到的问题,发现Java的AES加密出来的结果跟C#的AES加密出来的结果不一致

0
悬赏园豆:50 [待解决问题]

问题卡了几天了,希望懂java和C#双语言的劳烦帮忙解决一下,或者之前对结果java和C#的AES加密的童鞋帮忙给些提示,不胜感激.

先上java的加解密方法:

package com.uns.unspay.common;
import java.io.UnsupportedEncodingException;
import java.security.InvalidKeyException;
import java.security.NoSuchAlgorithmException;
import java.security.SecureRandom;
import javax.crypto.BadPaddingException;
import javax.crypto.Cipher;
import javax.crypto.IllegalBlockSizeException;
import javax.crypto.KeyGenerator;
import javax.crypto.NoSuchPaddingException;
import javax.crypto.SecretKey;
import javax.crypto.spec.SecretKeySpec;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

public class AESEncrypt {
private static String hexStr = "0123456789ABCDEF";
private static final Logger log = LoggerFactory.getLogger(AESEncrypt.class);
/**
 * 加密
 *
 * @param content
 *            需要加密的内容
 * @return
 */
public static String encrypt(String content, String privateKey) {
try {
KeyGenerator kgen = KeyGenerator.getInstance("AES");
SecureRandom secureRandom = SecureRandom.getInstance("SHA1PRNG");
secureRandom.setSeed(privateKey.getBytes());

kgen.init(128, secureRandom);
SecretKey secretKey = kgen.generateKey();
byte[] enCodeFormat = secretKey.getEncoded();
SecretKeySpec key = new SecretKeySpec(enCodeFormat, "AES");
Cipher cipher = Cipher.getInstance("AES");// 创建密码器
byte[] byteContent = content.getBytes("utf-8");
cipher.init(Cipher.ENCRYPT_MODE, key);// 初始化
byte[] result = cipher.doFinal(byteContent);
String strResult = BinaryToHexString(result);
return strResult; // 加密
} catch (NoSuchAlgorithmException e) {
log.error("Invalid Algorith.");
// e.printStackTrace();
} catch (NoSuchPaddingException e) {
log.error(e.getMessage(), e);
} catch (InvalidKeyException e) {
log.error(e.getMessage(), e);
} catch (UnsupportedEncodingException e) {
log.error(e.getMessage(), e);
} catch (IllegalBlockSizeException e) {
log.error(e.getMessage(), e);
} catch (BadPaddingException e) {
log.error(e.getMessage(), e);
}
return null;
}
/**
 * 
 * @param bytes
 * @return 将二进制转换为十六进制字符输出
 */
public static String BinaryToHexString(byte[] bytes) {
StringBuilder result = new StringBuilder();
StringBuilder hex = new StringBuilder();
for (int i = 0; i < bytes.length; i++) {
hex.delete(0, hex.length());
// 字节高4位
hex.append(String.valueOf(hexStr.charAt((bytes[i] & 0xF0) >> 4)));
// 字节低4位
hex.append(String.valueOf(hexStr.charAt(bytes[i] & 0x0F)));
result.append(hex);
}
return result.toString();
}
}
再上C#的加密方法
        #region AES加解密
        /// <summary>  
        ///AES加密(加密步骤)  
        ///1,加密字符串得到2进制数组;  
        ///2,将2禁止数组转为16进制;  
        ///3,进行base64编码  
        /// </summary>  
        /// <param name="toEncrypt">要加密的字符串</param>  
        /// <param name="key">密钥</param>  
        public static String AESEncrypt(String toEncrypt, String key)
        {
            Byte[] _Key = Encoding.ASCII.GetBytes(key);
            Byte[] _Source = Encoding.UTF8.GetBytes(toEncrypt);
            Aes aes = Aes.Create("AES");
            aes.Mode = CipherMode.ECB;
            aes.Padding = PaddingMode.PKCS7;
            aes.Key = _Key;
            ICryptoTransform cTransform = aes.CreateEncryptor();
            Byte[] cryptData = cTransform.TransformFinalBlock(_Source, 0, _Source.Length);
            String HexCryptString = Hex_2To16(cryptData);
            Byte[] HexCryptData = Encoding.UTF8.GetBytes(HexCryptString);
            String CryptString = Convert.ToBase64String(HexCryptData);
            return CryptString;           
        }
        /// <summary>  
        /// 2进制转16进制  
        /// </summary>  
        static String Hex_2To16(Byte[] bytes)
        {
            String hexString = String.Empty;
            Int32 iLength = 65535;
            if (bytes != null)
            {
                StringBuilder strB = new StringBuilder();

                if (bytes.Length < iLength)
                {
                    iLength = bytes.Length;
                }

                for (int i = 0; i < iLength; i++)
                {
                    strB.Append(bytes[i].ToString("X2"));
                }
                hexString = strB.ToString();
            }
            return hexString;
        }
假如待加密的字符串是:6226620620140212|张三|310101199001021212
密码:1234567890abcdef
那么java的加密结果是:2F04A64A3F452FE73C2B78185DBFFB0768C45D36CDA1113BE98AC1DDE9B97A1F48802DFBD8D56031F322D2AAB637FFE7
C#的加密结果是:
Q0I4ODZGNJE5NJRFRJJGRJM0RDCWNDK4MJIXRTZDNTC1NZAYRTE1NDLGRDDGNUVBNDGXRTQ2QJQ1OEUYNDG0MJVFN0Q2MJYZMZG5NJGYNTVGMUIXNKEZN0I5NDDGM0QY
发现两者不一致,特此请教各位,希望能得到加的解惑.

南宫萧尘的主页 南宫萧尘 | 初学一级 | 园豆:187
提问于:2018-02-27 15:00
< >
分享
所有回答(2)
0
dudu | 园豆:30925 (高人七级) | 2018-02-27 15:23
0

问题已解决,请参考这篇文章:http://www.cnblogs.com/cainiaoji/articles/6676500.html#3911417

南宫萧尘 | 园豆:187 (初学一级) | 2018-02-27 16:52
清除回答草稿
   您需要登录以后才能回答,未注册用户请先注册