java - 解密(使用 PHP)Java 加密(PBEWithMD5AndDES)

标签 java php cryptography md5 des

有人要求我用 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/

相关文章:

javascript - 将 JSON 响应放入 var 并输出

php - 替换数组值倍数

php - 如何获取数组中某个键的名称

java - 以编程方式设置按钮样式

java - 在 hibernate 中使用 join 时映射实体类

php - 防止在父级中打开的流套接字被子叉关闭

amazon-web-services - 保护为 AWS EC2 生成的私钥

java - 如何在 Java 中使用 ECC 对 key 进行非对称加密?

java - 为什么 IntelliJ IDEA 会发出此文件 javadoc 悬空的警告?

java - 无法将 BOOLEAN 列添加到我的 Derby 数据库中的表中