2013-03-01 17 views
5

私はjava.security.InvalidKeyExceptionを取得しています:キーサイズまたはデフォルトパラメータが正しくありません。インストールされたJava Cryptography Extension(JCE)無制限強度管轄ポリシーファイルをすべて削除しました。 はまた、私は、これらのスレッドを通じて無効なキー例外を助けてください

Java.security.InvalidKeyException: Illegal key size or default parameters error

Java Security: Illegal key size or default parameters?

を行っている。しかし、私はまだ立ち往生してjava.security.InvalidKeyExceptionを取得しています:不正なキーサイズまたはデフォルトのパラメータは、以下

が私のコードです: AESKeyGenerator.java

public class AESKeyGenerator { 

    private Cipher mCipher; 

    public AESKeyGenerator() 
    { 
     // default constructor 
    } 


    public byte[] generate_k(String dhkey, String toEncrypt) 
    { 
     byte[] retVal; 

     try { // Set up the Cipher class of Android to use AES to generate keys 
      byte[] iv = new byte[16]; 
      for (int i = 0; i < iv.length; i++) 
       iv[i] = new Byte("0").byteValue(); 
      IvParameterSpec ivspec = new IvParameterSpec(iv); 
      mCipher = Cipher.getInstance("AES"); 
      // Set up key to use in algorithm 
      MessageDigest hasher = MessageDigest.getInstance("SHA-256"); // Initialize object that will hash my key. 
      byte[] key256 = hasher.digest(dhkey.getBytes()); // Hash the key to 256 bits using SHA 
      SecretKeySpec K = new SecretKeySpec(key256, "AES"); 
      System.out.println("SecretKeySpec : "+K + " key256 "+key256); 
      mCipher.init(Cipher.ENCRYPT_MODE, K, ivspec); 
      // Encrypt the parameter toEncrypt 
      retVal = mCipher.doFinal(toEncrypt.getBytes()); 
      return retVal; 
     } 
     catch (Exception e) { 
         e.printStackTrace(); 
      System.err.println("Could not create and initialize object Cipher."); 
     } 

     return null; 

    } 

    public byte[] generate_r(byte[] sharedKey, String toEncrypt) 
    { 
     byte[] retVal; 
     try { 
      /*byte[] iv = new byte[16]; 
      for (int i = 0; i < iv.length; i++) 
       iv[i] = new Byte("0").byteValue(); 
      IvParameterSpec ivspec = new IvParameterSpec(iv);*/ 

      // Set up the Cipher class of Android to use AES to generate keys 
      mCipher = Cipher.getInstance("AES/ECB/PKCS5Padding"); 
      // Set up key to use in algorithm 
      MessageDigest hasher = MessageDigest.getInstance("SHA-256"); // Initialize object that will hash my key. 
      byte[] key256 = hasher.digest(sharedKey); // Hash the key to 256 bits using SHA 256 
      SecretKeySpec K = new SecretKeySpec(key256, "AES"); 
      mCipher.init(Cipher.ENCRYPT_MODE, K); 
      // Encrypt the parameter toEncrypt 
      System.out.println("toEncrypt AES: "+ toEncrypt); 
      retVal = mCipher.doFinal(toEncrypt.getBytes()); 
      return retVal; 
     } 
     catch (Exception e) { 
         e.printStackTrace(); 
      System.err.println("exception: "+ e.toString()); 
      System.err.println("Could not create and initialize object Cipher."); 
     } 

     return null; 

    } 
} 

私は取得しています休閑エラー:私もこれと同じである標準コードでチェック

java.security.InvalidKeyException: Illegal key size or default parameters 
    at javax.crypto.Cipher.checkCryptoPerm(Cipher.java:1010) 
    at javax.crypto.Cipher.implInit(Cipher.java:785) 
    at javax.crypto.Cipher.chooseProvider(Cipher.java:848) 
    at javax.crypto.Cipher.init(Cipher.java:1212) 
    at javax.crypto.Cipher.init(Cipher.java:1152) 
    at AESKeyGenerator.generate_r(AESKeyGenerator.java:74) 
    at DetectionServer.storeGridInformation(DetectionServer.java:309) 
    at DetectionServer.doPost(DetectionServer.java:103) 
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:641) 
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:722) 
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:304) 
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210) 
    at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:240) 
    at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:164) 
    at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:462) 
    at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:164) 
    at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:100) 
    at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:562) 
    at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:118) 
    at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:395) 
    at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:250) 
    at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:188) 
    at org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:302) 
    at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source) 
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source) 
    at java.lang.Thread.run(Unknown Source) 
exception: java.security.InvalidKeyException: Illegal key size or default parameters 
Could not create and initialize object Cipher. 

。私は設定やライブラリの不足にいくつかの問題があると思います。

+0

あなたはコメントがあります: '//Androidの暗号クラスを設定する'。あなたはちょうどどこかからそれをコピー/ペーストしましたか、またはこのコードはAndroidで動作していますか? –

答えて

5

私ははこれを再現することはできません - 私は現在Unlimited Strength Jurisdiction Policy Filesをインストールしていると私はテストを次のようにmainメソッドを使用している:以前のポリシーファイルをインストールする

public static void main(String[] args) throws UnsupportedEncodingException { 
    AESKeyGenerator aes = new AESKeyGenerator(); 
    String sharedKey = "Bar12345Bar12345Bar12345Bar12345"; 
    aes.generate_r(sharedKey.getBytes("US-ASCII"), "Hello World"); 
} 

を、私はあなたと同じ例外が発生しました。

まず最初に間違ったことは、Program files/jdk_1.7.0_13/jre/lib/securityにポリシーファイルをインストールしたことですが、使用されたJREはProgram files/jre7にあります。ポリシーファイルを適切な場所にインストールし、シンプルで確認してくださいスタンドアロンのJavaアプリケーションであれば、上記のmainメソッドを使用してください。

+1

Andreasさん、ありがとうございました。私は同じ誤りを犯していました。プログラムファイル/ jdk_1.7.0_13/jre/lib/securityにポリシーファイルをインストールしましたが、使用されたJREはProgram files/jre7 ...にあります私はファイル/ jre7にこれらのファイルをインストールしました。 – Raghvendra

1

あなたはそれを抽出して、あなたのJDKの場所のパスに2つのJARファイルをコピーして再起動し、このサイトにアクセスし、http://www.oracle.com/technetwork/java/javase/downloads/jce-7-download-432124.html ダウンロード(UnlimitedJCEPolicyJDK7.zip)をダウンロードする必要が,,私は同じ問題を抱えていますが、今で正常に動作しますプロジェクト。それはそれです

関連する問題