微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

AES php java 互转

 

PHP

<?PHP

class AesCrypt
{
    //初始化向量
    private $iv = '84195bd96a8a2e7f';

    //Mcrypt算法
    private $cipher = MCRYPT_RIJNDAEL_128;

    //Mcrypt支持的加密模型  特别适用于对文件进行加密。 相比 ECB, 它的安全性有明显提升。
    private $mode = MCRYPT_MODE_CBC;

    public function encrypt($str, $key = '')
    {
        $str = $this->addPKCS7Padding($str);

        $encrypted = mcrypt_encrypt($this->cipher, $key, $str, $this->mode, $this->iv);

        return $encrypted;
    }

    public function decrypt($code, $key = '')
    {
        $decrypted = mcrypt_decrypt($this->cipher, $key, $code, $this->mode, $this->iv);

        $decrypted = $this->stripPKSC7Padding($decrypted);

        return $decrypted;
    }

    protected function addPKCS7Padding($source)
    {
        $block = mcrypt_get_block_size($this->cipher, $this->mode);

        $pad = $block - (strlen($source) % $block);

        $char = chr($pad);

        $source .= str_repeat($char, $pad);

        return $source;
    }

    public function stripPKSC7Padding($source)
    {
        $char = substr($source, -1);
        $num = ord($char);
        $source = substr($source, 0, -$num);
        return $source;
    }
}

 

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐