加密函数是不是有错误?Crypt类,以静态调用非静态方法

浏览:954 发布日期:2016/04/21 分类:ThinkPHP5专区
 public static function encrypt($value, $key, $expire = 0, $target = 'url')
    {
        // 随机生成初始化向量, 增加密文随机性
        $iv = static::createIV(self::IV_SIZE);
        // 序列化待加密的数据(支持数组或对象的加密)
        $value = static::packing($value);
        // 加密数据
        $value = openssl_encrypt($value, self::CIPHER_MODE, $key, OPENSSL_RAW_DATA, $iv);
        if ($value === false) {
            return false;
        }
        // 加密有效期
        $expire = $expire ? dechex(time() + $expire) : 0;
        $expire = sprintf('%08s', $expire);
        // 生成密文校验码
        $hmac = static::hmac($iv, $value, $key);
        // 组合加密结果并base64编码
        return Base64::encode(pack('H*', $hmac . $expire) . $iv . $value, $target);
    }
而 base64类中的encode不是静态方法 public function encode($data, $target = '')
    {
        // 当函数没有特别指定编码目标时, 使用类自身编码目标
        if (empty($target)) {
            $target = self::$target;
        }
        // 进行一次原始编码
        $data = base64_encode($data);
        // 根据编码目标替换字符
        switch ($target) {
            case 'url':
                $data = str_replace(['+', '/', '='], ['-', '_', ''], $data);
                break;
            case 'regex':
                $data = str_replace(['+', '/', '='], ['!', '-', ''], $data);
                break;
            case 'default':
            default:
                break;
        }
        // 返回编码结果
        return $data;
    }
使用报错[2048] ErrorException in Crypt.php line 107
Non-static method org\transform\driver\Base64::encode() should not be called statically
最佳答案
评论( 相关
后面还有条评论,点击查看>>