sha1prng php,关于php下AES SHA1PRNG算法的加密

最近接入接口时遇到要求传输参数进行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));

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值