DES解密 - java加密 php解密

最近在做和其他公司的项目接口对接中,用到了DES加密解密

对方用的是java进行的开发,我这边需要调用对方的接口进行获取数据

接口参数,$appKey = "test" $appSecret = "123456789" $apiUrl = "http://www.xxx.com/api/?key=$appKey"

通过访问$apiUrl,会返回base64数据,需要通过base64_decode进行解码,解码后通过appSecret进行Des进行解密

附上代码:

function decrypt($crypt, $key, $iv) {
    // 对加密后的密文进行base64解码,用的是非标准的base64,要进行一下替换
    $crypt = str_replace(array('-', '_'), array('+', '/'), $crypt);
    $crypt = base64_decode($crypt);
    // 需要对appSecret进行md5加密,并且需要16字节长度的原始的二进制格式
    $key   = substr(md5($key, true), 0, 8);
    // MCRYPT_DES代表用DES算法加解密;MCRYPT_MODE_CBC代表使用cbc模式进行加解密.
    $encryption_descriptor = mcrypt_module_open(MCRYPT_DES, '', MCRYPT_MODE_CBC, '');
    mcrypt_generic_init($encryption_descriptor, $key, $iv);
    // 对$crypt进行解密
    $decrypted_data = mdecrypt_generic($encryption_descriptor, $crypt);
    mcrypt_generic_deinit($encryption_descriptor);
    mcrypt_module_close($encryption_descriptor);
    // 对解密后的明文进行去掉字符填充
    $decrypted_data = pkcs5_unpad($decrypted_data);
    $decrypted_data = rtrim($decrypted_data);

    return $decrypted_data;
}
/*
 * 去掉解密后的包含填充字符的明文中的填充字符
 */
function pkcs5_unpad($text) {
    $pad = ord($text{strlen($text) - 1});
    if ($pad > strlen($text)) {
        return false;
    }

    return substr($text, 0, -1 * $pad);
}

$plaintext = 'qz8XtwEl2XJptzJWYHY7bOjF65chTnBG-vTOgDRm9ILSrlMJs_jXno_PfB96YQEfsc3-BfAAWCaQHnXz8CmOlmjr3if7TuRW';
$key = "123456789";
$iv = "\x00\x01\x02\x03\x04\x05\x06\x07";
echo"Decrypt:\n";
$plaintext2 = decrypt($plaintext, $key, $iv);

转载于:https://my.oschina.net/yueguanqun/blog/1143030

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值