C#AES加密/解密和Java的加密结果不同

本文探讨了在C#中使用AES加密时,由于Java加密代码对密钥的特殊处理导致加密结果不一致的问题。解决方案在于C#端也需要对密钥进行相同的处理以匹配Java的加密结果。
摘要由CSDN通过智能技术生成

在Java的SES加密中,对加密的密钥进行了进一步的处理,代码如下:

        //1.构造密钥生成器,指定为AES算法,不区分大小写
		KeyGenerator keygen=KeyGenerator.getInstance("AES");
		//2.根据ecnodeRules规则初始化密钥生成器
		//生成一个128位的随机源,根据传入的字节数组
		SecureRandom random=SecureRandom.getInstance("SHA1PRNG");
		random.setSeed(encodeRules.getBytes());
		keygen.init(128, random);
		//3.产生原始对称密钥
		SecretKey original_key=keygen.generateKey();
		//4.获得原始对称密钥的字节数组
		byte [] raw=original_key.getEncoded();
		//5.根据字节数组生成AES密钥
		SecretKey key=new SecretKeySpec(raw, "AES");
        

所以,拷贝了网上很多分C#AES加密方法,加密的结果都不匹配

如果java对密钥进行了特殊处理后,需要在以前的AES加密中对密钥进行处理

            byte[] key
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值