研究pbootcms在使用api接口获取数据时,是怎么验证请求合法性的

www.jswusn.com PHP 2024-08-09 09:42:47 23次浏览

研究pbootcms在使用api接口获取数据时,是怎么验证请求合法性的

1、判断网站后台的api功能是否开启

if (! isset($config['api_open']) || ! $config['api_open']) {
    json(0, '系统尚未开启API功能,请到后台配置');
}


2、需要判断api的强制验证是否开启了

if ($config['api_auth']) {
 ...
}


3、判断网站后台的填写的api认证用户+api认证秘钥是否填写了

// 判断用户
if (! $config['api_appid']) {
    json(0, '请求失败:管理后台接口认证用户配置有误');
}
            
// 判断密钥
if (! $config['api_secret']) {
    json(0, '请求失败:管理后台接口认证密钥配置有误');
}


4、判断用户请求api时是否携带认证的参数

// 获取参数
if (! $appid = request('appid')) {
    json(0, '请求失败:未检查到appid参数');
}
if (! $timestamp = request('timestamp')) {
    json(0, '请求失败:未检查到timestamp参数');
}
if (! $signature = request('signature')) {
    json(0, '请求失败:未检查到signature参数');
}


5、验证用户请求api时携带的参数是否合法

// 验证时间戳
if (strpos($_SERVER['HTTP_REFERER'], get_http_url()) === false && time() - $timestamp > 15) { // 请求时间戳认证,不得超过15秒
    json(0, '请求失败:接口时间戳验证失败!');
}
            
// 验证签名
if ($signature != md5(md5($config['api_appid'] . $config['api_secret'] . $timestamp))) {
    error('请求失败:接口签名信息错误!');
}


至此验证通过后就可以等待服务器返回数据了


以下是完整代码

    /**
     * 客户端发起请求必须包含appid、timestamp、signature三个参数;
     * signature通过appid、secret、timestamp连接为一个字符串,然后进行双层md5加密生成;
     */
    public static function checkAccess($config)
    {
        if (! isset($config['api_open']) || ! $config['api_open']) {
            json(0, '系统尚未开启API功能,请到后台配置');
        }
        
        // 验证总开关
        if ($config['api_auth']) {
            
            // 判断用户
            if (! $config['api_appid']) {
                json(0, '请求失败:管理后台接口认证用户配置有误');
            }
            
            // 判断密钥
            if (! $config['api_secret']) {
                json(0, '请求失败:管理后台接口认证密钥配置有误');
            }
            
            // 获取参数
            if (! $appid = request('appid')) {
                json(0, '请求失败:未检查到appid参数');
            }
            if (! $timestamp = request('timestamp')) {
                json(0, '请求失败:未检查到timestamp参数');
            }
            if (! $signature = request('signature')) {
                json(0, '请求失败:未检查到signature参数');
            }
            
            // 验证时间戳
            if (strpos($_SERVER['HTTP_REFERER'], get_http_url()) === false && time() - $timestamp > 15) { // 请求时间戳认证,不得超过15秒
                json(0, '请求失败:接口时间戳验证失败!');
            }
            
            // 验证签名
            if ($signature != md5(md5($config['api_appid'] . $config['api_secret'] . $timestamp))) {
                error('请求失败:接口签名信息错误!');
            }
        }
    }


技术分享

苏南名片

  • 联系人:吴经理
  • 电话:152-1887-1916
  • 邮箱:message@jswusn.com
  • 地址:江苏省苏州市相城区

热门文章

Copyright © 2018-2024 jswusn.com 版权所有

技术支持:苏州网站建设  苏ICP备18036849号