Java实现ECDSA签名算法

 更新时间:2020年10月10日 16:21:04   作者:重设代码的天空  
这篇文章主要介绍了Java实现ECDSA签名算法,帮助大家更好得利用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));
  }
}

以上就是Java实现ECDSA签名算法的详细内容,更多关于Java ECDSA签名算法的资料请关注脚本之家其它相关文章!

相关文章

  • Java数据结构与算法之二分查找详解

    Java数据结构与算法之二分查找详解

    这篇文章主要介绍了Java数据结构与算法之二分查找详解,二分查找算法是一种在有序数组中查找某一特定元素的搜索算法,其思想就是不断地将有序查找表“一分为二”,逐渐缩小搜索区域,进而找到目标元素,需要的朋友可以参考下
    2023-12-12
  • java中的启动命令使用

    java中的启动命令使用

    本文详细介绍了Java启动参数的分类和具体用途,涵盖了基本内存管理、元空间管理、垃圾回收、性能调优与诊断、JavaAgent、系统属性以及应用执行等几类参数,通过合理配置这些参数,可以显著提升Java应用的性能、可管理性和可调试性
    2025-01-01
  • java实现ATM机系统(2.0版)

    java实现ATM机系统(2.0版)

    这篇文章主要为大家详细介绍了java实现ATM机系统2.0版,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-03-03
  • Java线程中sleep和wait的区别详细介绍

    Java线程中sleep和wait的区别详细介绍

    Java中的多线程是一种抢占式的机制,而不是分时机制。抢占式的机制是有多个线程处于可运行状态,但是只有一个线程在运行
    2012-11-11
  • java.lang.UnsatisfiedLinkError: %1 不是有效的Win32应用程序错误解决

    java.lang.UnsatisfiedLinkError: %1 不是有效的Win32应用程序错误解决

    这篇文章主要给大家介绍了关于java.lang.UnsatisfiedLinkError: %1 不是有效的Win32应用程序错误的解决方法,文中介绍的非常详细,需要的朋友们可以参考学习,下面来一起看看吧。
    2017-03-03
  • java程序员必须要学会的linux命令总结(推荐)

    java程序员必须要学会的linux命令总结(推荐)

    下面小编就为大家分享一篇java程序员必须要学会的linux命令总结(推荐)。具有很好的参考价值。希望对大家有所帮助。一起跟随小编过来看看吧
    2017-11-11
  • SpringCloud中的路由网关鉴权熔断详解

    SpringCloud中的路由网关鉴权熔断详解

    这篇文章主要介绍了SpringCloud中的路由网关鉴权熔断详解,Hystrix是一个用于处理分布式系统的延迟和容错的开源库,在分布式系统里,许多依赖不可避免的会调用失败,比如超时、异常等,需要的朋友可以参考下
    2024-01-01
  • Java 中的vector和list的区别和使用实例详解

    Java 中的vector和list的区别和使用实例详解

    在大家还没有了解vector,list,deque的知识之前,我先给大家介绍下stl,本文重点给大家介绍vector和list的区别及使用,感兴趣的的朋友一起看看吧
    2017-09-09
  • IDEA SSM框架整合配置及步骤详解

    IDEA SSM框架整合配置及步骤详解

    这篇文章主要介绍了IDEA SSM框架整合配置以及步骤,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-03-03
  • 推荐两款java开发实用工具 hutool 和 lombok

    推荐两款java开发实用工具 hutool 和 lombok

    通过本文给大家推荐两款java开发实用工具 hutool 和 lombok,本文通过实例代码给大家介绍的非常详细,需要的朋友参考下吧
    2021-04-04

最新评论