php实现 DES/CBC/PCCS5padding 加解密模式

<?php

/*
  名称:DES/CBC/PCCS5padding 模式加解密测试模块 
  功能:测试 使用 DES/CBC/PCCS5padding 模式进行加解密的模块
  作者:
  更新时间:
 */

//Quick Test
$h_user_password = “”;
$token_secret = "";
$token_key_with_oauth_nonce = “”;

$key = $token_secret;  //token_secret
$plaintext = $h_user_password; //h_user_password
$iv = $token_key_with_oauth_nonce; //token_key with oauth_nonce
echo "<b>String:</b> $plaintext <br><br>";
echo"<b>Encrypted:</b><br><br>";
$ciphertext = encrypt($plaintext, $key, $iv);
echo $ciphertext;
echo"<br><br><br><b>Decrypt:</b><br>";
$testplaintext2 = decrypt($ciphertext, $key, $iv);
echo $testplaintext2;

/*
 * 在采用DES加密算法,cbc模式,pkcs5Padding字符填充方式下,对明文进行加密函数
 */

function encrypt($input, $ky, $iv) {
    $key = $ky;
    $iv = $iv;  //$iv为加解密向量
    $size = 8; //填充块的大小,单位为bite    初始向量iv的位数要和进行pading的分组块大小相等!!!
    $input = pkcs5_pad($input, $size);  //对明文进行字符填充
    $td = mcrypt_module_open(MCRYPT_DES, '', 'cbc', '');    //MCRYPT_DES代表用DES算法加解密;'cbc'代表使用cbc模式进行加解密.
    mcrypt_generic_init($td, $key, $iv);
    $data = mcrypt_generic($td, $input);    //对$input进行加密
    mcrypt_generic_deinit($td);
    mcrypt_module_close($td);
    $data = base64_encode($data);   //对加密后的密文进行base64编码
    return $data;
}

/*
 * 在采用DES加密算法,cbc模式,pkcs5Padding字符填充方式,对密文进行解密函数
 */

function decrypt($crypt, $ky, $iv) {
    $crypt = base64_decode($crypt);   //对加密后的密文进行解base64编码
    $key = $ky;
    $iv = $iv;  //$iv为加解密向量
    $td = mcrypt_module_open(MCRYPT_DES, '', 'cbc', '');    //MCRYPT_DES代表用DES算法加解密;'cbc'代表使用cbc模式进行加解密.
    mcrypt_generic_init($td, $key, $iv);
    $decrypted_data = mdecrypt_generic($td, $crypt);    //对$input进行解密
    mcrypt_generic_deinit($td);
    mcrypt_module_close($td);
    $decrypted_data = pkcs5_unpad($decrypted_data); //对解密后的明文进行去掉字符填充
    $decrypted_data = rtrim($decrypted_data);   //去空格
    return $decrypted_data;
}

/*
 * 对明文进行给定块大小的字符填充
 */

function pkcs5_pad($text, $blocksize) {
    $pad = $blocksize - (strlen($text) % $blocksize);
    return $text . str_repeat(chr($pad), $pad);
}

/*
 * 对解密后的已字符填充的明文进行去掉填充字符
 */

function pkcs5_unpad($text) {
    $pad = ord($text{strlen($text) - 1});
    if ($pad > strlen($text))
        return false;
    return substr($text, 0, -1 * $pad);
}

?>


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值