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));
    }
}
posted @ 2020-09-14 16:46  重设代码的天空  阅读(934)  评论(0编辑  收藏  举报