3、还有一种办法,就是每次请求在redis的set集合中插入一个随机值,score为当时的时间,然后排序获取这段时间内的请求数量,代码如下
<?php
function checkrequest($_actkey) {
$_timeseconds = 5;//5秒内
$_timescount = 5; //智能访问5次
$zSetKey = "test12123".$_actkey;
$redis = new Redis();
$redis->connect('127.0.0.1', 6379);
$nowtime = time();
$startTime = $nowtime- $_timeseconds;
$requestHistory = $redis->zRangeByScore($zSetKey, $startTime, $nowtime);
if (count($requestHistory) >= $_timescount) {
return false;
} else {
$value = $nowtime . rand(0, 999);
$redis ->multi();
$redis->zAdd($zSetKey, [], $nowtime, $value);
$redis->zRemRangeByScore($zSetKey, 0, $startTime);
$redis->exec();
return true;
}
}
echo time();
var_dump(checkrequest("test"));
var_dump(checkrequest("test"));
var_dump(checkrequest("test"));
var_dump(checkrequest("test"));
echo time();
var_dump(checkrequest("test"));
echo time();
var_dump(checkrequest("test"));
echo time();
var_dump(checkrequest("test"));
网友回复
腾讯混元模型广场里都是混元模型的垂直小模型,如何api调用?
为啥所有的照片分辨率提升工具都会修改照片上的图案细节?
js如何在浏览器中将webm视频的声音分离为单独音频?
微信小程序如何播放第三方域名url的mp4视频?
ai多模态大模型能实时识别视频中的手语为文字吗?
如何远程调试别人的chrome浏览器获取调试信息?
为啥js打开新网页window.open设置窗口宽高无效?
浏览器中js的navigator.mediaDevices.getDisplayMedia屏幕录像无法录制SpeechSynthesisUtterance产生的说话声音?
js中mediaRecorder如何录制window.speechSynthesis声音音频并下载?
python如何直接获取抖音短视频的音频文件url?