刚学会走路的小猴 2023-03-20 11:49 采纳率: 50%
浏览 14
已结题

C#分块加密转JAVA如何实现

在C#里面,我引用SHA1加密一个明文,然后引用另一串明文进行分块加密,但是现在要转到JAVA里面实现,对于JAVA不是很了解,哈希的分块加密也没找到解释的文章,各位能给点思路吗?
如下是C#的实现方式:

public static void Main()
    {
        string passWord = "QWER1234.COM";
        string userWame = "03385";
        SHA1 sHA = SHA1.Create();
        byte[] bytes = Encoding.UTF8.GetBytes(passWord);
        byte[] bytes2 = Encoding.UTF8.GetBytes (userWame);
        byte[] buffer = sHA.ComputeHash (bytes);    
        Console.WriteLine("1-ComputeHash : {0}", BytesToStr(buffer));
        sHA.TransformBlock(bytes2, 0, bytes2.Length, bytes2, 0);
        Console.WriteLine("2-ComputeHash : {0}", BytesToStr(buffer));
        Console.WriteLine("3-ComputeHashBASE64 : {0}", Convert.ToBase64String(sHA.ComputeHash (buffer)));
    }

    public static string BytesToStr(byte[] bytes)
    {
        StringBuilder str = new StringBuilder();

        for (int i = 0; i < bytes.Length; i++)
            str.AppendFormat("{0:X2}", bytes[i]);

        return str.ToString();
    }

如下是控制台输出结果:
1-ComputeHash : 0D398019BAEBA2B26C7057E9DA0332364A2681DD
2-ComputeHash : 0D398019BAEBA2B26C7057E9DA0332364A2681DD
3-ComputeHashBASE64 : cbCE7PWS9MSwufR9LTs6+79F4kA=

  • 写回答

3条回答 默认 最新

  • MarkHan_ 2023-03-20 13:01
    关注

    该回答引用GPTᴼᴾᴱᴺᴬᴵ
    在Java中可以使用Java自带的MessageDigest类实现哈希算法,如SHA-1算法,可以使用以下代码:

    import java.security.MessageDigest;
    import java.security.NoSuchAlgorithmException;
    import java.nio.charset.StandardCharsets;
    
    public class SHA1Hash {
        public static void main(String[] args) {
            String password = "QWER1234.COM";
            String username = "03385";
    
            try {
                MessageDigest sha = MessageDigest.getInstance("SHA-1");
                byte[] passwordBytes = password.getBytes(StandardCharsets.UTF_8);
                byte[] usernameBytes = username.getBytes(StandardCharsets.UTF_8);
    
                byte[] buffer = sha.digest(passwordBytes);
                System.out.printf("1-ComputeHash : %s\n", bytesToHex(buffer));
    
                sha.update(usernameBytes, 0, usernameBytes.length);
                byte[] result = sha.digest();
                System.out.printf("2-ComputeHash : %s\n", bytesToHex(result));
                System.out.printf("3-ComputeHashBASE64 : %s\n", Base64.getEncoder().encodeToString(result));
            } catch (NoSuchAlgorithmException e) {
                e.printStackTrace();
            }
        }
    
        public static String bytesToHex(byte[] bytes) {
            StringBuilder hexString = new StringBuilder();
            for (byte b : bytes) {
                hexString.append(String.format("%02X", b));
            }
            return hexString.toString();
        }
    }
    
    

    分块加密可以在调用update方法之前先使用digest方法计算哈希值,然后再调用update方法对另一段明文进行分块加密。需要注意的是,在Java中,哈希值是不可逆的,无法还原明文,只能用于验证数据的完整性和一致性。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 3月28日
  • 已采纳回答 3月20日
  • 创建了问题 3月20日

悬赏问题

  • ¥15 用stata实现聚类的代码
  • ¥15 请问paddlehub能支持移动端开发吗?在Android studio上该如何部署?
  • ¥170 如图所示配置eNSP
  • ¥20 docker里部署springboot项目,访问不到扬声器
  • ¥15 netty整合springboot之后自动重连失效
  • ¥15 悬赏!微信开发者工具报错,求帮改
  • ¥20 wireshark抓不到vlan
  • ¥20 关于#stm32#的问题:需要指导自动酸碱滴定仪的原理图程序代码及仿真
  • ¥20 设计一款异域新娘的视频相亲软件需要哪些技术支持
  • ¥15 stata安慰剂检验作图但是真实值不出现在图上