PHP AES/CTR/PKCS7PADDING 加解密

本文使用aes-128-ctr进行加密。

至于aes-192-ctr、aes-256-ctr无非秘钥、填充位的长度不一样。直接百度好了。

在PHP中aes-128-ctr 没有自动计算填充位,需要自己手动计算。当时被坑了好久.....

aes-128-cbc就无需自己计算填充位.

加密填充:

public function enPKSC7($text){
        $block_size = 16; //128:16、256:32
        $text_length = strlen($text);
        //计算需要填充的位数
        $amount_to_pad = $block_size - ($text_length % $block_size);
        if ($amount_to_pad == 0) {
            $amount_to_pad = $block_size;
        }
        //获得补位所用的字符
        $pad_chr = chr($amount_to_pad);
        $tmp = "";
        for ($index = 0; $index < $amount_to_pad; $index++) {
            $tmp .= $pad_chr;
        }
        return $text . $tmp;
}

解密填充:

public function dePKSC7($text){
        $block_size = 16; //128:16、256:32
        $pad = ord(substr($text, -1));
        if ($pad < 1 || $pad > $block_size) {
            $pad = 0;
        }
        return substr($text, 0, (strlen($text) - $pad));
}

加密:

public function enAES_CTR($data, $key, $iv)
{
    $data = enPKSC7($data);  //填充
    $sign = openssl_encrypt($data, 'aes-128-ctr',$key, OPENSSL_RAW_DATA, $iv);
    return bin2hex($sign);
}

解密:

public static function deAES_CTR($data, $key, $iv)
{
    $sign = openssl_decrypt(hex2bin($data), 'aes-128-ctr',$key, OPENSSL_RAW_DATA, $iv);
    return dePKSC7($sign); //去掉填充位
}

本文输入输出为16进制结果。openssl_encrypt 具体参考文档,本文重点介绍填充处理。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值