为了账号安全,请及时绑定邮箱和手机立即绑定

C# DES 与 Java DES Byte[] 和 BlockSize 不同

C# DES 与 Java DES Byte[] 和 BlockSize 不同

叮当猫咪 2023-02-23 14:46:39
我正在努力让 Java 代码输出与 C# 代码相同的 Byte[]。C#代码:using System;using System.IO;using System.Security.Cryptography;using System.Text;public class Program{    private const string k = "A2B3C4D1";    private const string kiv = "1A2B3C4D";        public static void Main()    {        encrypt("peanuts");    }        public static void encrypt(string str)    {        try        {            using (var ms = new MemoryStream())            using (var csp = new DESCryptoServiceProvider() { Key = Encoding.UTF8.GetBytes(k), IV =  Encoding.UTF8.GetBytes(kiv) })            {                Console.WriteLine("Algorithm: DES?/" + csp.Mode + "/" + csp.Padding);                Console.WriteLine("BlockSize: " + csp.BlockSize);                using (var cs = new CryptoStream(ms, csp.CreateEncryptor(), CryptoStreamMode.Write))                using (var sw = new StreamWriter(cs))                    sw.WriteLine(str);                byte[] barray = ms.ToArray();                Console.WriteLine("barray length: " + barray.Length);                            Console.WriteLine("barray: " + string.Join(" ", barray));            }        }        catch (Exception ex) { Console.Write(ex.ToString()); }    }}Java代码:import java.io.ByteArrayOutputStream;import java.nio.charset.Charset;import java.security.Security;import javax.crypto.Cipher;import javax.crypto.CipherOutputStream;import javax.crypto.spec.IvParameterSpec;import javax.crypto.spec.SecretKeySpec;public class MyClass {    private static final String k = "A2B3C4D1";    private static final String kiv = "1A2B3C4D";        public static void main(String args[]) {        Security.addProvider(new org.bouncycastle.jce.provider.BouncyCastleProvider());        encrypt("peanuts");    }   
查看完整描述

1 回答

?
慕虎7371278

TA贡献1802条经验 获得超4个赞

您正在{ (byte)'p', (byte)'e', (byte)'a', (byte)'n', (byte)'u', (byte)'t', (byte)'s', (byte)'\r', (byte)'\n' }使用 C# 和{ (byte)'p', (byte)'e', (byte)'a', (byte)'n', (byte)'u', (byte)'t', (byte)'s' }Java 进行加密。


由于“peanuts”是(在 UTF-8 中)7 个字节,它可以被 PKCS7 填充到一个 DES 块中。接下来的 1-8 个字节导致第二个块......你添加了两个。


将 Dot.Net Fiddle 中的代码更改为Write而不是WriteLine生成


Algorithm: DES?/CBC/PKCS7

BlockSize: 64

barray length: 8

barray: 45 100 170 103 9 249 237 180

barray: LWSqZwn57bQ=

现在唯一的区别是 C# BlockSize 是位,而您的 Java 代码将它作为字节。


"peanuts"在你的"peanuts\r\n"JDoodle 中改为


Algorithm: DES/CBC/PKCS7Padding

BlockSize: 8

barray length: 16

barray:  107 125 91 -51 77 -50 98 120 -42 -62 64 -89 -128 97 -124 75

barray: a31bzU3OYnjWwkCngGGESw==

这是相同的,如果barray小数内容被打印为无符号值而不是有符号值(将 256 添加到所有负数)——在 Base64 中很容易看出这一事实是相同的。


查看完整回答
反对 回复 2023-02-23
  • 1 回答
  • 0 关注
  • 115 浏览

添加回答

举报

0/150
提交
取消
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号