最近接入接口时遇到要求传输参数进行aes加密,接口文档提供的java实例代码如下:
/**
* 加密函数
*
* @param content 加密的内容
* @param strKey 密钥
* @return 返回二进制字符数串
* @throws Exception
*/
public static byte[] enCrypt(String content, String strKey) throws Exception {
KeyGenerator keygen;
SecretKey desKey;
Cipher c;
byte[] cByte;
String str = content;
keygen = KeyGenerator.getInstance("AES");
SecureRandom random = SecureRandom.getInstance("SHA1PRNG");
random.setSeed(strKey.getBytes("utf-8"));
keygen.init(128, random);
// keygen.init(128, new SecureRandom(strKey.getBytes()));
desKey = keygen.generateKey();
c = Cipher.getInstance("AES");
c.init(Cipher.ENCRYPT_MODE, desKey);
cByte = c.doFinal(str.getBytes("UTF-8"));
return cByte;
}
/**
* 2 进制转化 16 进制
*
* @param buf
* @return
*/
public static String parseByte2HexStr(byte buf[]) {
StringBuffer sb = new StringBuffer();
for (int i = 0; i < buf.length; i++) {
String hex = Integer.toHexString(buf[i] & 0xFF);
if (hex.length() == 1) {
hex = '0' + hex;
}
sb.append(hex.toUpperCase());
}
return sb.toString();
}
php代码如下:
$key='123456';
$key = substr(openssl_digest(openssl_digest($key, 'sha1', true), 'sha1', true), 0, 16);
$data = openssl_encrypt($str, 'AES-128-ECB', $key, OPENSSL_RAW_DATA);
$data = strtolower(bin2hex($data));