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 签名 ecdsa_Java实现ECDSA签名算法相关推荐

  1. java 签名 ecdsa_Java数字签名——ECDSA算法

    ECDSA 例如微软产品的序列号的验证算法. Elliptic Curve Digital Signature Algorithm,椭圆曲线数字签名算法. 速度快,强度高,签名短 ---------- ...

  2. java ecdsa_Java实现ECDSA签名算法

    ECDSA签名算法 package com.albedo.security; /** * DSA 加解密实现 */ public class ECDSAUtils extends Base { //字 ...

  3. java签名软件_Java实现签名工具类

    一 点睛 签名和验证签名常常用于网络安全,在此提供一个工具类. 二 代码 package com.imooc.demo.common.util; import org.apache.commons.c ...

  4. java rsa数字签名_RSA 数字签名算法(Java版)

    数字签名算法Java版 还是上代码吧 public static final String SIGN_ALGORITHMS = "SHA1WithRSA"; /** * RSA签名 ...

  5. 密码学——ECDSA签名算法

    ECDSA算法原理及python实现 一.基本知识 1.1 概述 椭圆曲线数字签名算法(ECDSA)是使用椭圆曲线密码(ECC)对数字签名算法(DSA)的模拟,其安全性基于椭圆曲线离散对数问题.椭圆曲 ...

  6. java 签名 apk mac_java 方法签名

    public void test(){}()V public void test1(int i){}              (I)V public int test2(){ return 1;}( ...

  7. java 函数签名,Java签名getAlgorithm()方法

    可以使用getAlgorithm()类java.security.Signature中的方法获得签名对象的算法名称.此方法不需要任何参数,它返回签名对象的算法名称. 演示此的程序如下所示- 示例imp ...

  8. chinapay java_ECSHOP 银联电子支付(ChinaPay)插件 掉用JAVA签名

    帮客户集成接口时候发现客户网站PHP版本达不到要求 只要调用JAVA来解决问题<?php /** * ECSHOP 银联电子支付(ChinaPay)插件 * ================== ...

  9. php微信签名_PHP微信接口签名算法

    一.参数说明 二.安全规范 1.签名算法 签名生成的通用步骤如下: 第一步,设所有发送或者接收到的数据为集合M,将集合M内非空参数值的参数按照参数名ASCII码从小到大排序(字典序),使用URL键值对 ...

最新文章

  1. 小编带你进入强如 Disruptor 也发生内存溢出?
  2. Sklearn 损失函数如何应用到_15 分钟带你入门 sklearn 与机器学习(分类算法篇)...
  3. Cloudera发布全球企业数据成熟度报告,混合云趋势中有效数据战略是关键
  4. java没有更新_java – JProgressBar没有更新,找不到线索
  5. linux网络配置出现E325,Linux CentOS E325错误,如何解决?VI如何使用?
  6. 我用Vue3+TS实现了一个新年倒计时组件,适用于各种场景
  7. 【工具用法】Linux登录吉林大学校园网教程(以deepin为例)
  8. c#(webapi)获取当前项目路径
  9. chrome报Slow network is detected.
  10. 应届生面试这样准备,最能展现自己优势!
  11. java在线截图_JAVA之网页截屏
  12. matlab中如何输入积分,在matlab中怎么输入特殊符号,Matlab的符号积分
  13. S3C2440之IIC
  14. squeeze 、unsequeeze
  15. npm 和 yarn 安装和卸载包
  16. mysql numeric
  17. 2022年度总结——2022我在CSDN的那些事暨2023我的目标展望:Pursue freedom Realize self-worth
  18. Excel数据透视表不显示汇总行
  19. 应用卷积神经网络对乳腺癌组织病理图像进行分类
  20. antd table分页,关于react的antd表格分页的问题

热门文章

  1. 更改应用程序图标_苹果更新 TestFlight 应用图标,增加更多拟真细节
  2. 彻底卸载acer软件保护卡_宏碁(Acer)传奇 14英寸 新一代7nm六核处理器 真香机 高性能宏基笔记本电脑(R5-4500U 7纳米 16G 512GSSD )...
  3. html5怎么自动生成meta标签,html中meta标签该如何使用
  4. python多进程写入mysql_Python实现 多进程导入CSV数据到 MySQL
  5. 电脑c语言怎么调出来的,c语言系统源代码_C语言判断系统版本的代码怎样将值调出来啊...
  6. c语言中循环结构的作用,C语言中对于循环结构优化的一些入门级方法简介
  7. java垃圾回收 分代_Java分代垃圾回收策略原理详解
  8. python 发邮件 timeout_Python邮件发送/带附件发送
  9. qt中update()的粗略理解
  10. C语言 #pragma once - C语言零基础入门教程