YII2 restful 限流

之前用豆瓣的API时,会有一分钟只能请求40次的限制;通过Yii2来实现这样的限制:

    public static function tryLimit($key, $prefix, $timeLimit, $tryTimes){
        $times = Yii::$app->cache->get($key . $prefix);
        if (!$times) {
            $times = 0;
        }
        if ($times >= $tryTimes) { //一小时只能获取$tryTimes次
            throw new TooManyRequestsHttpException("Too Many Requests");
        } else {
            Yii::$app->cache->set($key . $prefix, $times + 1, $timeLimit);
        }
    }

    public static function controllerLimit($params, $funcName)
    {
        foreach ($params as $v) {
            if ($v['funciton'] == $funcName) {
                self::tryLimit($v['funciton'], (string)Yii::$app->request->userIP, $v['time_limit'], $v['try_times']);
            }
        }
    }

在xxxController加入限制

    public function init()
    {
        if (in_array(Yii::$app->requestedRoute, [
            'user/info'
        ])) {
            //限制IP访问接口次数(60秒访问只能访问40次)
            self::controllerLimit([
                [
                    'funciton' => 'user/info',
                    'time_limit' => 60,
                    'try_times' => 40,
                ]
            ], Yii::$app->requestedRoute);
        }
    }

常用状态码

200: OK。一切正常。
201: 响应 POST 请求时成功创建一个资源。Location header 包含的URL指向新创建的资源。
204: 该请求被成功处理,响应不包含正文内容 (类似 DELETE 请求)。
304: 资源没有被修改。可以使用缓存的版本。
400: 错误的请求。可能通过用户方面的多种原因引起的,例如在请求体内有无效的JSON 数据,无效的操作参数,等等。
401: 验证失败。
403: 已经经过身份验证的用户不允许访问指定的 API 末端。
404: 所请求的资源不存在。
405: 不被允许的方法。 请检查 Allow header 允许的HTTP方法。
415: 不支持的媒体类型。 所请求的内容类型或版本号是无效的。
422: 数据验证失败 (例如,响应一个 POST 请求)。 请检查响应体内详细的错误消息。
429: 请求过多。 由于限速请求被拒绝。
500: 内部服务器错误。 这可能是由于内部程序错误引起的

Yii2中$model->load(Yii::$app->request->get())一直返回false

使用$model->load()方法时一直返回false,网上找许久,有说是安全问题的,加个参数就可以了,于是:

$model->load(Yii::$app->request->get(),true)

可还是没有解决,看代码:

public function load($data, $formName = null)
{
    $scope = $formName === null ? $this->formName() : $formName;
    if ($scope === '' && !empty($data)) {
            $this->setAttributes($data);

            return true;
        } elseif (isset($data[$scope])) {
            $this->setAttributes($data[$scope]);

            return true;
        }

        return false;
}

load()方法有两个参数,第一个参数 $data 是要填充的数据,第二个参数 $formName 是选择指定的模型。如果第二个参数不传,$formName 会默认为null,默认取当前模型 $this->formName()。如果指定了模型,会将模型名称作为key值,通过 $data[$formName] 取值,也就是这时候应该传的 $data 格式是:

$data = [
    'User' => [
        'name' => 'test',
        'phone' => '13000000000',
        'email' => '[email protected]'
    ]
];

如果 $formName 传空字符串,则 $data 传递参数格式为:

$data = [
    'name' => 'test',
    'phone' => '13000000000',
    'email' => '[email protected]'
];

这时应该用:

$model->load($data, '');

还有一种解决办法:

$model->attributes = $data;
// 或者
$model->setAttributes($data);

CENTOS 7 YUM 安装PHP7.4

安装源

yum install epel-release
yum install http://rpms.remirepo.net/enterprise/remi-release-7.rpm

安装YUM管理工具

yum install yum-utils

搜索

yum search php74

安装PHP

yum install php74-php-gd  php74-php-pdo php74-php-mbstring php74-php-cli php74-php-fpm php74-php-mysqlnd

启动

service php74-php-fpm start