2017-11-05 23 views
0

私はBouncycastleを学び、いくつかの問題に直面しています。その後、私のサーバ側で私が書いたBouncycastleProviderはjava.lang.NoSuchFieldErrorをスローします:id_hmacWithSHA3_224

security.provider.11=org.bouncycastle.jsse.provider.BouncyCastleJsseProvider 
security.provider.12=org.bouncycastle.jce.provider.BouncyCastleProvider 
security.provider.13=org.bouncycastle.jcajce.provider.BouncyCastleFipsProvider 

...  
SSLContext sslContext = SSLContext.getInstance("TLS", "BCJSSE"); 
KeyManagerFactory keyMgrFact = KeyManagerFactory.getInstance(
       "PKIX", "BCJSSE"); 
keyMgrFact.init(Utils.createServerKeyStore(), Utils.SERVER_PASSWORD); 
... 

をそれがでエラーがスローされます は、それは私がように私のjava.securityを変更したなどとして、複数のセキュリティプロバイダを組み合わせることが可能です:

public static KeyPair generateRootKeyPair() 
      throws Exception { 

     KeyFactory kFact = KeyFactory.getInstance("RSA", "BC"); 
     return new KeyPair(
       kFact.generatePublic(new X509EncodedKeySpec(rootPublicKey)), 
       kFact.generatePrivate(new PKCS8EncodedKeySpec(rootPrivateKey))); 
    } 

エラーメッセージ:

Exception in thread "main" java.lang.NoSuchFieldError: id_hmacWithSHA3_224 
    at org.bouncycastle.jcajce.provider.digest.SHA3$Mappings.configure(Unknown Source) 
    at org.bouncycastle.jce.provider.BouncyCastleProvider.loadAlgorithms(Unknown Source) 
    at org.bouncycastle.jce.provider.BouncyCastleProvider.setup(Unknown Source) 
    at org.bouncycastle.jce.provider.BouncyCastleProvider.access$000(Unknown Source) 
    at org.bouncycastle.jce.provider.BouncyCastleProvider$1.run(Unknown Source) 
    at java.security.AccessController.doPrivileged(Native Method) 
    at org.bouncycastle.jce.provider.BouncyCastleProvider.<init>(Unknown Source) 
    at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method) 
    at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:62) 
    at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45) 
    at java.lang.reflect.Constructor.newInstance(Constructor.java:423) 
    at java.lang.Class.newInstance(Class.java:442) 
    at sun.security.jca.ProviderConfig$2.run(ProviderConfig.java:221) 
    at sun.security.jca.ProviderConfig$2.run(ProviderConfig.java:206) 
    at java.security.AccessController.doPrivileged(Native Method) 
    at sun.security.jca.ProviderConfig.doLoadProvider(ProviderConfig.java:206) 
    at sun.security.jca.ProviderConfig.getProvider(ProviderConfig.java:187) 
    at sun.security.jca.ProviderList.getProvider(ProviderList.java:233) 
    at sun.security.jca.ProviderList.getIndex(ProviderList.java:263) 
    at sun.security.jca.ProviderList.getProviderConfig(ProviderList.java:247) 
    at sun.security.jca.ProviderList.getProvider(ProviderList.java:253) 
    at sun.security.jca.GetInstance.getService(GetInstance.java:81) 
    at sun.security.jca.GetInstance.getInstance(GetInstance.java:206) 
    at java.security.KeyFactory.getInstance(KeyFactory.java:211) 
    at Utils.generateRootKeyPair(Utils.java:103) 
    at Utils.createRootCredential(Utils.java:199) 
    at Utils.createServerKeyStore(Utils.java:273) 
    at TLSServerExample.main(TLSServerExample.java:19) 
私は日のカップルのためにそれを研究している

、私はこの問題の原因は、パッケージ間のいくつかの衝突があると思っている:

bc-fips-1.0.0 
bcprov-jdk15on-158.jar 
bctls-fips-1.0.2.jar 

それを修正する方法は? Thx in advancee!

答えて

0

私ははBouncyCastleで同様のエラーを得ていた、私の場合は、不一致またはそのバージョン

+0

は、あなたの根本的な原因に展開することができましたか? ' org.bouncycastle bcprov-jdk15on 1.58 org.bouncycastle :私は、私はこの二つの依存関係を使用しようとしている、同様の問題を取得していますbcpkix-jdk15on 1.58 ' しかし私はBouncyCastleをインスタンス化できませんでした: ' Security.addProvider(new BouncyCastleProvider()); ' それをインスタンス化することはできず、java.lang.NoSuchFieldErrorで失敗します:id_hmacWithSHA3_224 –

関連する問題