• java DSA Signature Sign And Verify


    SignatureSignAndVerify

    import java.security.KeyPair;
    import java.security.KeyPairGenerator;
    import java.security.PrivateKey;
    import java.security.PublicKey;
    import java.security.SecureRandom;
    import java.security.Security;
    import java.security.Signature;
    
    public class SignatureSignAndVerify {
    
          public static void main(String args[]) throws Exception {
            Security.addProvider(new org.bouncycastle.jce.provider.BouncyCastleProvider());
    
            KeyPair keyPair = generateKeyPair(999);
    
            byte[] data = { 65, 66, 67, 68, 69, 70, 71, 72, 73, 74 };
            byte[] digitalSignature = signData(data, keyPair.getPrivate());
    
            boolean verified;
    
            verified = verifySig(data, keyPair.getPublic(), digitalSignature);
            System.out.println(verified) ;
    
            keyPair = generateKeyPair(888);
            verified = verifySig(data, keyPair.getPublic(), digitalSignature);
            System.out.println(verified);
    
          }
    
          public static byte[] signData(byte[] data, PrivateKey key) throws Exception {
            Signature signer = Signature.getInstance("SHA1withDSA");
            signer.initSign(key);
            signer.update(data);
            return (signer.sign());
          }
    
          public static boolean verifySig(byte[] data, PublicKey key, byte[] sig) throws Exception {
            Signature signer = Signature.getInstance("SHA1withDSA");
            signer.initVerify(key);
            signer.update(data);
            return (signer.verify(sig));
    
          }
    
          public static KeyPair generateKeyPair(long seed) throws Exception {
            Security.addProvider(new org.bouncycastle.jce.provider.BouncyCastleProvider());
            KeyPairGenerator keyGenerator = KeyPairGenerator.getInstance("DSA");
            SecureRandom rng = SecureRandom.getInstance("SHA1PRNG", "SUN");
            rng.setSeed(seed);
            keyGenerator.initialize(1024, rng);
    
            return (keyGenerator.generateKeyPair());
          }
    }
  • 相关阅读:
    表单的重复提交问题
    js日期操作
    spring data jpa
    Excel Xll开发资料
    Excel DNA学习笔记一
    error LNK1123: 转换到 COFF 期间失败: 文件无效或损坏的解决方案
    点进去勿喷
    hdu1305(字典树)
    2018 Multi-University Training Contest 3
    hihocoder 1014(字典树)
  • 原文地址:https://www.cnblogs.com/rojas/p/4578466.html
Copyright © 2020-2023  润新知