久久久久久久av_日韩在线中文_看一级毛片视频_日本精品二区_成人深夜福利视频_武道仙尊动漫在线观看

在 Java 中使用 BouncyCastle 使用 ECIES 進(jìn)行加密

Using BouncyCastle to encrypt with ECIES in Java(在 Java 中使用 BouncyCastle 使用 ECIES 進(jìn)行加密)
本文介紹了在 Java 中使用 BouncyCastle 使用 ECIES 進(jìn)行加密的處理方法,對(duì)大家解決問(wèn)題具有一定的參考價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)吧!

問(wèn)題描述

我正在嘗試使用 Java 中的 BouncyCastle 使用 ECC 算法加密一些內(nèi)容.但是我收到 BouncyCastle 庫(kù)的異常,說(shuō)不能將 JCEECPublicKey 轉(zhuǎn)換為 IESKey.據(jù)我了解, KeyPairGenerator 生成的公鑰是 JCEECPublicKey ,不能在 java Cipher.init 方法中使用.有人可以告訴我如何將它轉(zhuǎn)換為公鑰或 X509 規(guī)范,以便我可以在加密中使用它.

I am trying to encrypt some content using ECC algorithm using BouncyCastle in java. But I am getting exception of BouncyCastle library saying cannot cast JCEECPublicKey to IESKey. Which I understood that the public key generated by KeyPairGenerator is JCEECPublicKey which cannot be used in java Cipher.init method. Can someone tell me how can convert it in Public key or X509 spec so that I can use it in encryption.

這是我嘗試過(guò)的代碼

// add instance of provider class
Security.addProvider(new BouncyCastleProvider());

// initializing parameter specs secp256r1/prime192v1
ECParameterSpec ecSpec = ECNamedCurveTable.getParameterSpec("prime192v1");

// key pair generator to generate public and private key
KeyPairGenerator generator = KeyPairGenerator.getInstance("ECDH", new BouncyCastleProvider());

// initialize key pair generator
generator.initialize(ecSpec);

// Key pair to store public and private key
KeyPair keyPair = generator.generateKeyPair();

Cipher iesCipher = Cipher.getInstance("ECIES", new BouncyCastleProvider());
iesCipher.init(Cipher.ENCRYPT_MODE, keyPair.getPublic());

我也嘗試將公鑰轉(zhuǎn)換為 X509EncodedSpec 但我得到同樣的異常

Also I tried to convert the public key into X509EncodedSpec but I get same exception

X509EncodedKeySpec spec = new X509EncodedKeySpec(keyPair.getPublic().getEncoded());
KeyFactory factory = KeyFactory.getInstance("ECDH");

PublicKey publicKey = factory.generatePublic(spec);

我得到的例外是

java.lang.ClassCastException: org.bouncycastle.jce.provider.JCEECPublicKey cannot be cast to org.bouncycastle.jce.interfaces.IESKey
    at org.bouncycastle.jce.provider.JCEIESCipher.engineGetKeySize(JCEIESCipher.java:49)
    at javax.crypto.Cipher.passCryptoPermCheck(Cipher.java:1057)
    at javax.crypto.Cipher.checkCryptoPerm(Cipher.java:1015)
    at javax.crypto.Cipher.init(Cipher.java:1229)
    at javax.crypto.Cipher.init(Cipher.java:1173)
    at com.test.EciesTest.main(EciesTest.java:45)

編輯

根據(jù)評(píng)論,我使用的 JDK 版本是 JDK 7 - Oracle我正在使用的導(dǎo)入語(yǔ)句:

Based on comment the JDK version I am using is JDK 7 - Oracle Import statements I am using:

import java.security.KeyPair;
import java.security.KeyPairGenerator;
import java.security.Security;
import java.security.spec.ECGenParameterSpec;
import javax.crypto.Cipher;
import org.bouncycastle.jce.provider.BouncyCastleProvider;

推薦答案

試試以下:

// add instance of provider class
Security.addProvider(new BouncyCastleProvider());

String name = "secp256r1";

// NOTE just "EC" also seems to work here
KeyPairGenerator kpg = KeyPairGenerator.getInstance("ECDH", BouncyCastleProvider.PROVIDER_NAME);
kpg.initialize(new ECGenParameterSpec(name));

// Key pair to store public and private key
KeyPair keyPair = kpg.generateKeyPair();

Cipher iesCipher = Cipher.getInstance("ECIES", BouncyCastleProvider.PROVIDER_NAME);
iesCipher.init(Cipher.ENCRYPT_MODE, keyPair.getPublic());

請(qǐng)注意,在嘗試通過(guò) JCE 使用 Bouncy 時(shí),通常最好保留 JCE 類(lèi)而不是 Bouncy Castle 類(lèi).在這種情況下,問(wèn)題可能是提供給密鑰生成器的參數(shù).

And note that in general it is best to keep to JCE classes instead of Bouncy Castle classes when trying to use Bouncy through the JCE. In this case the problem was probably the parameters given to the key generator.

在上面的代碼中,我使用了 BouncyCastleProvider.PROVIDER_NAME 但只是 "BC" 當(dāng)然同樣可以正常工作.每次都重新實(shí)例化提供者不是一個(gè)好主意,盡管它不應(yīng)該影響最終結(jié)果.

In above code I used BouncyCastleProvider.PROVIDER_NAME but just "BC" would work equally well of course. Re-instantiating the provider each time is not a good idea, although it should not have influenced the end result.

確保您擁有運(yùn)行此代碼的最新系統(tǒng).此代碼已在以下系統(tǒng)上測(cè)試:

Make sure you've got an up to date system to run this code. This code was tested on the following system:

 --- runtime information --- 
Properties:
    java.vendor                : Oracle Corporation
    java.specification.name    : Java Platform API Specification
    java.specification.version : 1.8
    java.runtime.name          : Java(TM) SE Runtime Environment
    java.runtime.version       : 1.8.0_65-b17
    java.vm.name               : Java HotSpot(TM) 64-Bit Server VM
Unlimited crypto: yes
 --- info for provider Bouncy Castle --- 
Bouncy Castle version: 1.520000
Bouncy Castle provider registered: yes

這篇關(guān)于在 Java 中使用 BouncyCastle 使用 ECIES 進(jìn)行加密的文章就介紹到這了,希望我們推薦的答案對(duì)大家有所幫助,也希望大家多多支持html5模板網(wǎng)!

【網(wǎng)站聲明】本站部分內(nèi)容來(lái)源于互聯(lián)網(wǎng),旨在幫助大家更快的解決問(wèn)題,如果有圖片或者內(nèi)容侵犯了您的權(quán)益,請(qǐng)聯(lián)系我們刪除處理,感謝您的支持!

相關(guān)文檔推薦

Java Remove Duplicates from an Array?(Java從數(shù)組中刪除重復(fù)項(xiàng)?)
How to fix Invocation failed Unexpected Response from Server: Unauthorized in Android studio(如何修復(fù)調(diào)用失敗來(lái)自服務(wù)器的意外響應(yīng):在 Android 工作室中未經(jīng)授權(quán))
AES encryption, got extra trash characters in decrypted file(AES 加密,解密文件中有多余的垃圾字符)
AES Error: Given final block not properly padded(AES 錯(cuò)誤:給定的最終塊未正確填充)
Detecting incorrect key using AES/GCM in JAVA(在 JAVA 中使用 AES/GCM 檢測(cè)不正確的密鑰)
AES-256-CBC in Java(Java 中的 AES-256-CBC)
主站蜘蛛池模板: 99精品国产一区二区三区 | 最近中文字幕在线视频1 | 日日摸日日碰夜夜爽亚洲精品蜜乳 | 国产精品视频在线观看 | 久久最新 | 天天夜碰日日摸日日澡 | 午夜精品久久久久久久久久久久久 | 北条麻妃国产九九九精品小说 | 91人人看 | 欧美亚洲免费 | 久久精品网| 成人福利在线视频 | 麻豆hd | 中文字幕不卡在线观看 | 久久精品1| 亚洲最大成人综合 | 九九热这里 | 亚洲精品免费观看 | 日本黄色大片免费看 | 日本精品一区二区三区在线观看视频 | 国产精品久久久久久久岛一牛影视 | 国产小视频在线 | 在线成人免费视频 | 亚洲精品一二区 | 久久黄色 | 久久精品日产第一区二区三区 | 天天干天天色 | 日韩av一二三区 | 久久99国产精品久久99果冻传媒 | 国产一区在线免费观看 | 久久99国产精一区二区三区 | 日韩av啪啪网站大全免费观看 | 美国a级毛片免费视频 | 欧美二区在线 | 免费观看一级黄色录像 | 爽爽免费视频 | 福利精品在线观看 | 国产精品成人一区二区三区 | 亚洲精品国产成人 | 天天干天天爱天天 | 日韩精品在线观看免费 |