PHP笔记-AES加解密(PHP7)

x33g5p2x  于2022-03-01 转载在 PHP  
字(0.8k)|赞(0)|评价(0)|浏览(294)

运行截图:

首先要修改php.ini,这个php_openssl.dll要放开

构造工具类:

<?php

namespace vendor;

class EncryptionTool{

    public static function enAES($originTxt, $key): string{

        return base64_encode(openssl_encrypt($originTxt, 'AES-128-ECB',$key, OPENSSL_RAW_DATA));
    }

    public static function deAES($originTxt, $key): string{

        $data = base64_decode($originTxt);
        return openssl_decrypt($data,'AES-128-ECB',$key, OPENSSL_RAW_DATA);
    }
    
}

这里要注意的地方。

AES有很多种加密方式如ECB、CBC、CTR、OFB、CFB

数据块有128位、192位、256位

填充方式有pkcs5padding、pkcs7padding、zeropadding、iso10126、ansix923、no padding。

php调用的openssl默认是采用pkcs7padding

调用代码如下:

$hello = "Hello World";

echo "原始数据: " . $hello . "<br/>";
$data = EncryptionTool::enAES($hello, "1234567891234567");
echo "加密后: " . $data . "<br/>";
echo "解密后: " . EncryptionTool::deAES($data, "1234567891234567") . "<br/>";

相关文章

微信公众号

最新文章

更多