PHP openssl_encrypt openssl_decrypt 尝试

7 篇文章 0 订阅

/*
 可以用来做数据的加密和解密

*/


class Openssl
{

    private $key = null;
    private $data = null;
    private $cipher = null;
    private $iv = null;
    private $preKey = 'xxx:xxx:';

    function __construct($data = '', $key = '', $cipher = "") {
        $this->data = $data;
        $this->key = $key;
        $this->cipher = in_array($cipher, openssl_get_cipher_methods()) ? $cipher : "aes-128-cbc";
    }

    public function getIv() {
        $this->iv =  $this->iv ? $this->iv : openssl_random_pseudo_bytes(openssl_cipher_iv_length($this->cipher));
        return $this->iv;
    }

    public function setPreKey($preKey) {
        $this->preKey = $preKey;
        return $this;
    }

    public function setIv($iv) {
        if (!empty($iv)) {
            $this->iv = $iv;
        }
        return $this;
    }

    public function setKey($key) {
        if (!empty($key)) {
            $this->key = $key;
        }
        return $this;
    }

    public function setData($data) {
        if (!empty($data)) {
            $this->data = $data;
        }
        return $this;
    }

    public function encrypt() {
        if (empty($this->key) || empty($this->data)) {
            return false;
        }
        return openssl_encrypt($this->data, $this->cipher, $this->preKey.$this->key, 0, $this->getIv());
    } 

    public function decrypt() {
        if (empty($this->key) || empty($this->data)) {
            return false;
        }
        return openssl_decrypt($this->data, $this->cipher, $this->preKey.$this->key, 0, $this->getIv());
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
PHP5中,可以使用`openssl_encrypt`和`openssl_decrypt`函数来实现SM4算法的加密和解密。 下面是一个示例代码: ```php function sm4_encrypt($data, $key) { $iv = openssl_random_pseudo_bytes(openssl_cipher_iv_length('sm4-cbc')); $encrypted = openssl_encrypt($data, 'sm4-cbc', $key, OPENSSL_RAW_DATA, $iv); return base64_encode($iv . $encrypted); } function sm4_decrypt($data, $key) { $data = base64_decode($data); $iv = substr($data, 0, openssl_cipher_iv_length('sm4-cbc')); $encrypted = substr($data, openssl_cipher_iv_length('sm4-cbc')); return openssl_decrypt($encrypted, 'sm4-cbc', $key, OPENSSL_RAW_DATA, $iv); } // 测试 $data = "hello world"; $key = "this is a key"; $encrypted = sm4_encrypt($data, $key); $decrypted = sm4_decrypt($encrypted, $key); echo "加密后的数据: " . $encrypted . "\n"; echo "解密后的数据: " . $decrypted . "\n"; ``` 在这段代码中,`sm4_encrypt`函数使用`openssl_encrypt`函数对数据进行加密,然后用base64编码返回加密后的结果。`sm4_decrypt`函数则对base64解码后的数据进行解密,并返回解密后的结果。在测试中,我们使用了一个字符串作为数据,一个字符串作为密钥,然后对数据进行加密和解密。 需要注意的是,在使用SM4算法时,需要使用`sm4-cbc`算法模式,并且需要提供一个随机的初始化向量(IV)来增加加密的强度。在本例中,我们使用`openssl_random_pseudo_bytes`函数生成一个随机的IV。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值