zoukankan      html  css  js  c++  java
  • java中的数据加密4 数字签名

      数字签名

      它是确定交换消息的通信方身份的第一个级别。A通过使用公钥加密数据后发给B,B利用私钥解密就得到了需要的数据,问题来了,由于都是使用公钥加密,那么如何检验是A发过来的消息呢?上面也提到了一点,私钥是唯一的,那么A就可以利用A自己的私钥进行加密,然后B再利用A的公钥来解密,就可以了;数字签名的原理就基于此,而通常为了证明发送数据的真实性,通过利用消息摘要获得简短的消息内容,然后再利用私钥进行加密散列数据和消息一起发送

    import java.security.KeyPair;
    import java.security.KeyPairGenerator;
    import java.security.Signature;
    import java.security.SignatureException;
    
    public class DigitalSignature {
        public static void main(String[] args) throws Exception {
            byte[] srcText = "digital Signature test".getBytes("UTF8");
            // 形成RSA公钥对
            KeyPairGenerator keyGen = KeyPairGenerator.getInstance("RSA");
            keyGen.initialize(1024);
            KeyPair key = keyGen.generateKeyPair();
            // 使用私鈅签名
            Signature sig = Signature.getInstance("SHA1WithRSA");
            sig.initSign(key.getPrivate());
            sig.update(srcText);
            byte[] signature = sig.sign();
            System.out.println(sig.getProvider().getInfo());
            System.out.println(new String(signature, "UTF8"));
            // 使用公鈅验证
            sig.initVerify(key.getPublic());
            sig.update(srcText);
            try {
                if (sig.verify(signature)) {
                    System.out.println("Signature verified");
                } else
                    System.out.println("Signature failed");
            } catch (SignatureException e) {
                System.out.println("Signature failed");
            }
        }
    
    }
  • 相关阅读:
    Mybaits利用插件generator自动生成sql
    idea设置
    centos虚拟机的相关知识
    nginx部署
    apollo配置
    分布式报错解决方案
    搭建springconfigCenter遇到的坑
    idea中git配置
    SpringCloudDay1_概念
    03.2020 MB SD Connect C4 Software “set_SDconnect.bat” File Lost Error Solution
  • 原文地址:https://www.cnblogs.com/happyPawpaw/p/3740782.html
Copyright © 2011-2022 走看看