Dieser Artikel stellt allen die Zugriffshäufigkeitsbeschränkung für die PHP-Schnittstelle vor. Ich hoffe, dass er Freunden in Not hilfreich sein wird!
Ich habe festgestellt, dass viele Einschränkungen im Internet nur Zugriffsbeschränkungen innerhalb einer Minute (oder einer bestimmten Zeit) sind.
Wenn das Limit beispielsweise 10 Mal in 1 Minute beträgt, dann habe ich in 59 Sekunden 10 Mal darauf zugegriffen, und dann ist der Schlüssel wieder abgelaufen und ich kann in der nächsten Minute wieder darauf zugreifen. Diese Einschränkung ist einfach unzumutbar.
Hier ist also meine Idee.
Gehen Sie einfach zum Code.
/** * @param $uid * @return bool|int * 检测用户接口访问频率 */ function api_frequency_visits ($uid) { $key = "user:{$uid}:api:frequency"; $redis = new Redis(); $redis->connect('127.0.0.1'); $data = $redis->hGetAll($key); //需要删除的key $del_key = []; //时间内访问的总次数 $total = 0; //时间内最大访问次数 $max_frequency = 10; //当前时间 $now_time = time(); //限制时间 $limit_time = 60; foreach ($data as $time=>$count) { if ($time < $now_time - $limit_time) { $del_key[] = $time; } else { $total += $count; } } //存在需要删除的key if ($del_key) { $redis->hDel($key, ...$del_key); } if ($total >= $max_frequency) { return false; } return $redis->hIncrBy($key, $now_time, 1); } $uid = 1; $result = api_frequency_visits($uid); if (!$result) { echo json_encode(['code'=>0, 'msg'=>'操作过于频繁', 'data'=>[]]);die; } echo json_encode(['code'=>1, 'msg'=>'', 'data'=>[ 'uid'=>$uid, 'other'=>rand() ]]);die;
Das Zeitlimit und die Häufigkeit können geändert werden, einschließlich der Änderung des gewünschten Limits basierend auf der Benutzer-ID, wie IP usw.
Die Ablaufzeit des Schlüssels kann ebenfalls hinzugefügt werden.
Empfohlen: „PHP-Video-Tutorial“
Das obige ist der detaillierte Inhalt vonDetaillierte Erläuterung der Zugriffshäufigkeitsbegrenzung der PHP-Schnittstelle. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!