この記事では、PHP インターフェースのアクセス頻度制限について皆さんに紹介しますので、困っている友人の役に立てれば幸いです。
インターネット上の制限の多くは、1 分 (または一定時間) 以内のアクセス制限のみであることがわかりました。
たとえば、制限が 1 分あたり 10 回の場合、59 秒間に 10 回アクセスすると、キーの有効期限が再び切れ、次の 1 分で再びアクセスできるようになります。この制限はまったく不合理です。
それで、私には考えがあります。
コードをアップロードするだけです。
/** * @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;
制限時間と回数は、IP などのユーザー ID に基づいて希望する制限に変更するなど、変更できます。
キーの有効期限を追加することもできます。
推奨: 「PHP ビデオ チュートリアル 」
以上がPHPインターフェースのアクセス回数制限の詳細説明の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。