2012-10-16 74 views
0

我试图将加密和解密函数转换为在Java中用于以下PHP。但收到非法密钥大小错误。建议我在java中进行256位AES解密。将PHP加密和解密方法转换为java

PHP代码

<?php 
    function encrypt ($data,$salt) { 
     $hash = base64_encode(mcrypt_encrypt(MCRYPT_RIJNDAEL_256, md5($salt), $data, MCRYPT_MODE_CBC, md5(md5($salt)))); 
     return $hash; 
    } 
    function decrypt ($encdata,$salt) { 
     $string = mcrypt_decrypt(MCRYPT_RIJNDAEL_256, md5($salt), base64_decode($encdata), MCRYPT_MODE_CBC, md5(md5($salt))); 
     return $string; 
    } 
?> 

转换Java代码:

//The below code found in http://www.logikdev.com/2010/11/01/encrypt-with-php-decrypt-with-java/ 
    public static String md5(String input) throws NoSuchAlgorithmException { 
     MessageDigest md = MessageDigest.getInstance("MD5"); 
     byte[] messageDigest = md.digest(input.getBytes()); 
     BigInteger number = new BigInteger(1, messageDigest); 
     return number.toString(16); 
    } 

    public String decrypt(String encryptedData) { 
     String decryptedData = null; 
     try { 
      SecretKeySpec skeySpec = new SecretKeySpec(md5("5A17K3Y").getBytes(), "AES");   
      String initialVectorString=md5(md5("5A17K3Y")); 
      IvParameterSpec initialVector = new IvParameterSpec(initialVectorString.getBytes()); 
      Cipher cipher = Cipher.getInstance("AES/CBC/PKCS5Padding","SunJCE");    
      cipher.init(Cipher.DECRYPT_MODE, skeySpec, initialVector);   
      encryptedData=encryptedData.replace('-','+').replace('_','/').replace(',','='); 
      byte[] encryptedByteArray = (new org.apache.commons.codec.binary.Base64()).decode((encryptedData.getBytes()));   
      byte[] decryptedByteArray = cipher.doFinal(encryptedByteArray); 
      decryptedData = new String(decryptedByteArray, "UTF8"); 
     } catch (Exception e) {   
      System.out.println("Error. Problem decrypting the data: " + e); 
     } 
    } 

问题对数据进行解密:java.security.InvalidKeyException:非法密钥大小

回答

0

您会收到一个非法如果您尚未安装无限强度管辖区文件,则会出现密钥大小错误。这些文件允许Java使用更强的密钥长度(例如256位AES)。

转到Oracle download site并寻找与您的Java版本匹配的文件。如果您所在的国家/地区合法,请安装这些文件并享受更强大的加密。

附注:你是否研究过这个问题?第一个​​表现会回答你的问题)。