java和php加密_JAVA PHP加密解密

我的应用程序中有以下加密功能:

public static String encrypt(String key, String value) {

try {

IvParameterSpec iv = new IvParameterSpec(key.substring(0, 16).getBytes("UTF-8"));

SecretKeySpec skeySpec = new SecretKeySpec(key.getBytes("UTF-8"), "AES");

Cipher cipher = Cipher.getInstance("AES/CBC/PKCS5Padding");

cipher.init(Cipher.ENCRYPT_MODE, skeySpec, iv);

byte[] encrypted = cipher.doFinal(value.getBytes("UTF-8"));

return Base64.encodeBase64String(encrypted);

} catch (Exception ex) {

ex.printStackTrace();

}

return null;

}

在PHP中,使用openssl_decrypt()解码加密消息,并将AES-128-CBC设置为加密方法.

然而,解密总是失败我从服务器得到的响应是它无法识别加密方法.

我无法控制服务器,因此我无法仅在我的Java应用程序中更改任何内容.

我尝试过不同的模式,如AES / CBC / NoPadding,但我得到一个例外

Input Length Not Multiple of 16 bytes

现在我知道加密没有任何问题,因为我在使用AES / CBC / PKCS5Pad时能够在我的java应用程序中加密和解密它在发布到服务器时失败了.

密钥是md5哈希.

这是我需要加密的数据示例:

{

"merchant_id": "EXX-00000001",

"user_id": "000000000001",

"code": "000200",

"details": {

"acc_no": "1234691007924321",

"exp": "07/19",

"name": "MICHAEL XXXXXX",

"type": "VIS"

}

}

只应对“详细信息”值进行加密.代码应该是md5哈希.然后,生成的哈希将用作AES加密的密钥. IV应该是哈希的前16个字符.加密完成后,结果应在base64中编码并发送到服务器.

解决方法:

试图扭转这种局面,我得到了一个错误

java.security.InvalidKeyException: Illegal key size

在线

cipher.init(Cipher.ENCRYPT_MODE, skeySpec, iv);

为了使它工作,我将SecretKeySpec字节数组从key.getBytes(“UTF-8”)更改为key.substring(0,16).getBytes(“UTF-8”)并使用它如下:

String md5Key= "e510a13edeea112b57683d724d5d70a6";

String detailsData = "{\n" +

" \"acc_no\": \"1234691007924321\",\n" +

" \"exp\": \"07/19\",\n" +

" \"name\": \"MICHAEL XXXXXX\",\n" +

" \"type\": \"VIS\"\n" +

" }";

System.out.println(encrypt(md5Key, detailsData));

我有这样的输出:

iufp4Rl+x/yTO7hSQBH7uU63sXAyzxgLequ3+JkFYZFz3PWwhxDC87TEC+bZ4rirgZVasrkLE1ehWWRGFV42Z29vAok+TMdwOvOettELUD3g8W2F40OyjMg4ItYkiZM+2W6Q2zf6t4sLzM6/AYqmAy1dKjPJcCQaFcnqK6mUFcM=

为了在PHP中解密,我使用以下代码,使用密钥的前16个字符将其用作键和iv初始值设定项,如下所示:

$enc_data = 'iufp4Rl+x/yTO7hSQBH7uU63sXAyzxgLequ3+JkFYZFz3PWwhxDC87TEC+bZ4rirgZVasrkLE1ehWWRGFV42Z29vAok+TMdwOvOettELUD3g8W2F40OyjMg4ItYkiZM+2W6Q2zf6t4sLzM6/AYqmAy1dKjPJcCQaFcnqK6mUFcM=';

$key = 'e510a13edeea112b57683d724d5d70a6';

$key16 = substr($key, 0, 16);

$key16Hex = unpack('H*', $key16);

print openssl_decrypt($enc_data, "AES-128-CBC", $key16, 0, hex2bin($key16Hex[1]));

当然,我得到了用Java加密的想要的JSON数据:

{

"acc_no": "1234691007924321",

"exp": "07/19",

"name": "MICHAEL XXXXXX",

"type": "VIS"

}

奇怪的是你没有在这一行得到错误:

SecretKeySpec skeySpec = new SecretKeySpec(key.getBytes("UTF-8"), "AES");

因为我使用JDK 1.8:

import javax.crypto.Cipher;

import javax.crypto.spec.IvParameterSpec;

import javax.crypto.spec.SecretKeySpec;

import org.apache.commons.codec.binary.Base64;

标签:php,java,encryption,jax-rs

来源: https://codeday.me/bug/20190522/1153815.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值