有人要求我用 PHP 解密使用以下 Java 类加密的字符串。
public class CryptoLibrary {
private Cipher encryptCipher;
private sun.misc.BASE64Encoder encoder = new sun.misc.BASE64Encoder();
public CryptoLibrary() throws SecurityException{
java.security.Security.addProvider(new com.sun.crypto.provider.SunJCE());
char[] pass = "NNSHHETJKKSNKH".toCharArray();
byte[] salt = {
(byte) 0xa3, (byte) 0x21, (byte) 0x24, (byte) 0x2c,
(byte) 0xf2, (byte) 0xd2, (byte) 0x3e, (byte) 0x19 };
init(pass, salt, iterations);
}
public void init(char[] pass, byte[] salt, int iterations)throws SecurityException{
PBEParameterSpec ps = new javax.crypto.spec.PBEParameterSpec(salt, 20);
SecretKeyFactory kf = SecretKeyFactory.getInstance("PBEWithMD5AndDES");
SecretKey k = kf.generateSecret(new javax.crypto.spec.PBEKeySpec(pass));
encryptCipher = Cipher.getInstance("PBEWithMD5AndDES/CBC/PKCS5Padding");
encryptCipher.init(Cipher.ENCRYPT_MODE, k, ps);
}
}
public synchronized String encrypt(String str) throws SecurityException{
if(str!=null){
byte[] utf8 = str.getBytes("UTF8");
byte[] enc = encryptCipher.doFinal(utf8);
return encoder.encode(enc);
}
else {
return null;
}
}
}
我不懂 Java,所以我需要一些帮助来理解这种加密。
1) 这行的含义是什么?
PBEParameterSpec ps = new javax.crypto.spec.PBEParameterSpec(salt,20);
2) 我应该为第一个参数使用什么值
字符串 mcrypt_encrypt ( 字符串 $cipher , 字符串 $key , 字符串 $data , 字符串 $mode [, 字符串 $iv ] )
3) 我什么时候应该在 PHP 脚本中使用 MD5?
最佳答案
我必须为我的客户做同样的事情,并编写了几行代码来帮助解决问题:https://github.com/kevinsandow/PBEWithMD5AndDES
关于java - 解密(使用 PHP)Java 加密(PBEWithMD5AndDES),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10300185/