zoukankan      html  css  js  c++  java
  • DSA签名算法实现

    DSA签名

    package com.albedo.security;
    
    /**
     * DSA 加解密实现
     */
    public class DSAUtils extends Base {
    
        //字符编码
        public static final String ALGORITHM = "DSA";
        public static final String SIGN_ALGORITHM = "SHA1withDSA";
    
    
        /**
         * DSA 验签
         *
         * @param str       加密字符串
         * @param publicKey 公钥
         * @return 密文
         * @throws Exception 加密过程中的异常信息
         */
        public static boolean verify(String sign, String str, String publicKey) throws Exception {
            return verify(sign, str, publicKey, ALGORITHM, SIGN_ALGORITHM);
        }
    
        /**
         * DSA 签名
         *
         * @param str        加密字符串
         * @param privateKey 私钥
         * @return 铭文
         * @throws Exception 解密过程中的异常信息
         */
        public static String sign(String str, String privateKey) throws Exception {
            return sign(str, privateKey, ALGORITHM, SIGN_ALGORITHM);
        }
    
    
        public static void main(String[] args) throws Exception {
            String publicKey = getPublicKey(ALGORITHM, 1024);
            String privateKey = getPrivateKey(ALGORITHM, 1024);
            String message = "我要测试DSA";
            String sign = sign(message, privateKey);
            System.out.println(verify(sign, message, publicKey));
        }
    }

    基类实现

    package com.albedo.security;
    
    import com.albedo.num.ByteUtils;
    
    import java.security.KeyFactory;
    import java.security.KeyPair;
    import java.security.KeyPairGenerator;
    import java.security.PrivateKey;
    import java.security.PublicKey;
    import java.security.Signature;
    import java.security.spec.PKCS8EncodedKeySpec;
    import java.security.spec.X509EncodedKeySpec;
    import java.util.Objects;
    
    class Base {
        static KeyPair keyPair;
    
        /**
         * 生成密钥实际方法,可以使用多种方式
         * 一篇文档提供一下多种方式
         * { "DSA", "SHA1withDSA", "1024" }, { "DSA", "SHA256withDSA", "1024" },
         * { "DSA", "SHA256withDSA", "2048" }, { "RSA", "SHA256withRSA", "1024" },
         * { "RSA", "SHA256withRSA", "2048" }, { "RSA", "SHA256withRSA", "3192" },
         * { "RSA", "SHA512withRSA", "1024" }, { "RSA", "SHA512withRSA", "2048" },
         * { "RSA", "SHA512withRSA", "3192" }, { "RSA", "MD5withRSA", "1024" },
         * { "RSA", "MD5withRSA", "2048" },
         * { "RSA", "MD5withRSA", "3192" }, { "EC", "SHA1withECDSA", "128" },
         * { "EC", "SHA1withECDSA", "256" },
         * { "EC", "SHA256withECDSA", "128" }, { "EC", "SHA256withECDSA", "256" },
         * { "EC", "SHA512withECDSA", "128" }, { "EC", "SHA512withECDSA", "256" },
         *
         * @param algorithm
         * @param bit
         * @return
         * @throws Exception
         */
        protected static KeyPair createKey(String algorithm, int bit) throws Exception {
            KeyPairGenerator keyPairGenerator = KeyPairGenerator.getInstance(algorithm);
            keyPairGenerator.initialize(bit);
            KeyPair keyPair = keyPairGenerator.generateKeyPair();
            return keyPair;
        }
    
    
    
    
        /**
         * 获取公钥
         *
         * @return
         * @throws Exception
         */
        public static String getPublicKey(String algorithm,int bit) throws Exception {
            if (Objects.isNull(keyPair)) {
                keyPair = createKey(algorithm,bit);
            }
            return ByteUtils.byteArr2HexStr(keyPair.getPublic().getEncoded());
    
        }
    
        /**
         * 获取私钥
         *
         * @return
         * @throws Exception
         */
        public static String getPrivateKey(String algorithm,int bit) throws Exception {
            if (Objects.isNull(keyPair)) {
                keyPair = createKey(algorithm,bit);
            }
            return ByteUtils.byteArr2HexStr(keyPair.getPrivate().getEncoded());
    
        }
        /**
         * 非对称加密签名
         * @param str
         * @param privateKey
         * @param algorithm
         * @param signAlgorithm
         * @return
         * @throws Exception
         */
        public static String sign(String str, String privateKey, String algorithm, String signAlgorithm) throws Exception {
            PKCS8EncodedKeySpec pkcs8EncodedKeySpec = new PKCS8EncodedKeySpec(ByteUtils.hexstr2ByteArr(privateKey));
            KeyFactory keyFactory = KeyFactory.getInstance(algorithm);
            PrivateKey dsaPrivateKey = keyFactory.generatePrivate(pkcs8EncodedKeySpec);
            Signature signature = Signature.getInstance(signAlgorithm);
            signature.initSign(dsaPrivateKey);
            signature.update(str.getBytes());
            return ByteUtils.byteArr2HexStr(signature.sign());
        }
    
        /**
         * 非对称加密验证
         * @param sign
         * @param str
         * @param publicKey
         * @param algorithm
         * @param signAlgorithm
         * @return
         * @throws Exception
         */
        public static boolean verify(String sign, String str, String publicKey,String algorithm,String signAlgorithm) throws Exception {
            //base64编码的公钥
            X509EncodedKeySpec x509EncodedKeySpec = new X509EncodedKeySpec(ByteUtils.hexstr2ByteArr(publicKey));
            KeyFactory keyFactory = KeyFactory.getInstance(algorithm);
            PublicKey dsaPublicKey = keyFactory.generatePublic(x509EncodedKeySpec);
            Signature signature = Signature.getInstance(signAlgorithm);
            signature.initVerify(dsaPublicKey);
            signature.update(str.getBytes());
            return signature.verify(ByteUtils.hexstr2ByteArr(sign));
        }
    }
  • 相关阅读:
    web网站接入谷歌登录
    ThinkPHP网页端网站应用接入微信登录
    [卡特兰数]
    KALI LINUX 工具大全概览(长期更新中。。。)
    如何使用burp suite 来pj验证码
    windows小技巧(长期更新)
    如何关闭火绒自启动
    VMware USB Arbitration Service服务-错误3:系统找不到指定的路径
    windows下的burpsuite v2021.7 安装与配置
    拿到一台新window应该做些什么事
  • 原文地址:https://www.cnblogs.com/wangzxblog/p/13667634.html
Copyright © 2011-2022 走看看