Java实现ECDSA签名算法
时间:2021-07-09 08:28:01|栏目:JAVA代码|点击: 次
ECDSA签名算法
package com.albedo.security;
/**
* DSA 加解密实现
*/
public class ECDSAUtils extends Base {
//字符编码
public static final String ALGORITHM = "EC";
public static final String SIGN_ALGORITHM = "SHA1withECDSA";
/**
* ECDSA 验签
*
* @param sign 加密签名
* @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);
}
/**
* ECDSA 签名
*
* @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, 512);
String privateKey = getPrivateKey(ALGORITHM, 512);
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));
}
}
上一篇:SpringMVC 方法四种类型返回值总结(你用过几种)
栏 目:JAVA代码
下一篇:SpringBoot集成阿里巴巴Druid监控的示例代码
本文标题:Java实现ECDSA签名算法
本文地址:http://www.codeinn.net/misctech/154915.html


阅读排行
- 1Java Swing组件BoxLayout布局用法示例
- 2java中-jar 与nohup的对比
- 3Java邮件发送程序(可以同时发给多个地址、可以带附件)
- 4Caused by: java.lang.ClassNotFoundException: org.objectweb.asm.Type异常
- 5Java中自定义异常详解及实例代码
- 6深入理解Java中的克隆
- 7java读取excel文件的两种方法
- 8解析SpringSecurity+JWT认证流程实现
- 9spring boot里增加表单验证hibernate-validator并在freemarker模板里显示错误信息(推荐)
- 10深入解析java虚拟机




