国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術(shù)文章
文章詳情頁

Java實現(xiàn)ECDSA簽名算法

瀏覽:7日期:2022-08-22 18:40:09

ECDSA簽名算法

package com.albedo.security;/** * DSA 加解密實現(xiàn) */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)); }}

基礎(chǔ)代碼

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實現(xiàn)ECDSA簽名算法的詳細(xì)內(nèi)容,更多關(guān)于Java ECDSA簽名算法的資料請關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: Java
相關(guān)文章:
主站蜘蛛池模板: 99国产精品农村一级毛片 | 日本精品高清一区二区不卡 | 久久九九视频 | 亚洲人成人毛片无遮挡 | 国产成人在线视频播放 | 91亚洲精品一区二区福利 | 久久视频6免费观看视频精品 | 在线播放人成午夜免费视频 | 亚洲gogo人体大胆西西安徽 | 深夜福利视频在线观看免费播放 | 国产精品黄网站免费进入 | 国内精品小视频福利网址 | 性欧美精品孕妇 | 天堂一区二区在线观看 | 亚洲欧美日韩国产一区二区精品 | 免费看欧美毛片大片免费看 | 精品 日韩 国产 欧美在线观看 | 成人爽a毛片在线视频网站 成人爽爽大片在线观看 | 久久福利青草精品资源站 | 69成人做爰视频69 | 99久久久久国产 | 国产高清晰在线播放 | 国产成人啪精品午夜在线观看 | 国产成人a大片大片在线播放 | 综合 91在线精品 | 欧美真人视频一级毛片 | 国产男人天堂 | 99久久亚洲综合精品网站 | 亚欧视频在线观看 | 成年人免费在线观看网站 | 亚洲片在线观看 | 99精品在线观看视频 | 日韩中文字幕在线看 | 日韩有码第一页 | 国产精品久久久久久久9999 | 曰批美女免费视频播放 | 亚洲视频在线观看 | 日本 国产 欧美 | 黄色三级三级三级 | 久久久国产精品福利免费 | 91香焦视频 |