日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > java >内容正文

java

java 签名 ecdsa_Java实现ECDSA签名算法

發布時間:2025/3/8 java 36 豆豆
生活随笔 收集整理的這篇文章主要介紹了 java 签名 ecdsa_Java实现ECDSA签名算法 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

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签名算法的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 国产鲁鲁视频在线观看特色 | 亚洲国产av一区二区 | 老头糟蹋新婚少妇系列小说 | av毛片在线免费观看 | 日日爱夜夜操 | 精品国产乱码久久久久久图片 | 538在线精品| 黄a毛片| 欧美性爱精品一区 | 在线观看免费日韩av | 五月婷婷狠狠爱 | 精品丝袜一区 | 欧美一区二三区 | 欧美日韩成人在线视频 | 免费在线观看一区 | 加勒比色综合 | 色老头一区| 欧美狠狠爱 | 久久大| 91啪国产在线 | 超碰成人97 | 精品久久久久久无码国产 | 超碰成人在线免费观看 | 美女的胸给男人玩视频 | 久久午夜影视 | 午夜精品无码一区二区三区 | 99re久久精品国产 | 色呦呦官网| 亚洲另类一区二区 | 91一区二区视频 | 性做久久久久久免费观看 | 日本精品一区在线 | 在线观看免费黄色 | 久久婷婷av | 午夜少妇影院 | 夜夜嗨aⅴ一区二区三区 | 国产精品免费看 | 日韩视频不卡 | 国产福利观看 | www亚洲天堂 | 我色综合 | 麻豆精品免费观看 | 日韩亚洲精品中文字幕 | 热逼视频 | 射射射综合网 | 日韩欧美在线观看一区二区三区 | 波多野结衣久久 | 欧美日韩性生活视频 | 黄免费在线观看 | 精品午夜一区二区 | 亚洲黄色影院 | 农村黄色片| 五月天婷婷基地 | 亚洲无人禁区 | 成人av手机在线 | 欧美人与牲动xxxx | av毛片在线免费看 | 亚洲天堂一区二区在线 | 国产精品999在线观看 | 日本亚洲一区二区 | 96久久精品 | av女星全部名单 | 色婷婷综合久久久久中文一区二区 | 精品乱码一区二区三区四区 | 四虎网站在线 | 精品久久久久久久久久久久 | 自拍在线视频 | 中文字幕1区2区 | 性欧美极品另类 | 国产精品久久久久影院 | 日韩在线观看视频一区二区三区 | 无码人妻丰满熟妇精品区 | 蜜臀999 | 91久久爱| 青在线视频 | 少妇视频在线 | 国产古装艳史毛片hd | 欧美精品99 | 四虎成人永久免费视频 | 香蕉网在线视频 | 日韩精品在线一区 | 国产情侣免费视频 | 中文字幕有码在线视频 | 亚洲欧美偷拍一区 | 领导揉我胸亲奶揉下面 | 星空大象在线观看免费播放 | 中文字幕乱码人妻无码久久 | 天堂av一区二区三区 | 欧美11p| 爱逼综合| 国产精品久久久久久久一区探花 | www.在线观看麻豆 | 人妻毛片 | 久久精品一区二区免费播放 | 国产精品一区一区三区 | 一区二区高清在线 | 色综网 | 亚洲精品一线二线三线 | www.色婷婷 |