[PHP]利用openssl_random_pseudo_bytes和base64_encode函数来生成随机字符串

本文介绍了如何利用PHP的openssl_random_pseudo_bytes函数配合base64_encode生成随机字符串。通过base64_encode处理随机字节,并去除不必要的字符。同时建议在使用前检查openssl_random_pseudo_bytes函数是否存在,如果不可用则提供备选方案。
摘要由CSDN通过智能技术生成

openssl_random_pseudo_bytes函数本身是用来生成指定个数的随机字节,因此在使用它来生成随机字符串时,还需要配合使用函数base64_encode。如下所示:

public static function getRandomString($length = 42)
    {
   
        /*
         * Use OpenSSL (if available)
         */
        if (function_exists('openssl_random_pseudo_bytes')) {
            $bytes = openssl_rando
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
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。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值