PHP7.2+ 版本,DEC-CBC加解密

代码备份录——PHP7.2 加解密之—— DES-CBC

加解密

public static function encrypt($str,$key){
        $str = urlencode($str);
        $str = base64_encode($str);
        $str = self::pkcsPadding($str, 8);
        // 此处根据自己不同偏移量进行修改
        $v = $key;//pack('H*', "1234567890abcdef"); 
        $key = str_pad($key, 8, '0'); // 3DES加密将8改为24
        $sign = openssl_encrypt($str, 'DES-CBC', $key,OPENSSL_RAW_DATA | OPENSSL_NO_PADDING,$v);
        $sign = strtoupper(bin2hex($sign));
        return $sign;
    }

    //des解密(cbc模式)
    public static function decrypt($encrypted,$key){
        $encrypted = hex2bin($encrypted);
        // 此处根据自己不同偏移量进行修改
        $v = $key;//pack('H*', "1234567890abcdef");
        $key = str_pad($key, 8, '0'); // 3DES加密将8改为24
        $sign = @openssl_decrypt($encrypted, 'DES-CBC', $key,OPENSSL_RAW_DATA | OPENSSL_NO_PADDING,$v);
        $sign = self::unPkcsPadding($sign);
        $sign = rtrim($sign);
        $sign = base64_decode($sign);
        $sign = urldecode($sign);
        return $sign;
    }

相关代码

    /**
     * 填充
     * @param $str
     * @param $blocksize
     * @return string
     */
    private static function pkcsPadding($str, $blocksize){
        $pad = $blocksize - (strlen($str) % $blocksize);
        return $str . str_repeat(chr($pad), $pad);

    }

    /**
     * 去填充
     * @param $str
     * @return string
     */
    private static function unPkcsPadding($str){
        $pad = ord($str{strlen($str) - 1});
        if ($pad > strlen($str)) {
            return false;
        }
        if (strspn($str, chr($pad), strlen($str) - $pad) != $pad){
            return false;
        }
        return substr($str, 0, -1 * $pad);
    }
本作品采用《CC 协议》,转载必须注明作者和本文链接
朝着梦,踏平坎坷
《L04 微信小程序从零到发布》
从小程序个人账户申请开始,带你一步步进行开发一个微信小程序,直到提交微信控制台上线发布。
《G01 Go 实战入门》
从零开始带你一步步开发一个 Go 博客项目,让你在最短的时间内学会使用 Go 进行编码。项目结构很大程度上参考了 Laravel。
讨论数量: 3

这么好的帖子怎么就没有人顶呢,谢谢分享

2年前 评论

unPkcsPadding 和 pkcsPadding,这两个函数没有哦

2年前 评论
wavebossy6666 (楼主) 2年前

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!