硬件发送http post(get,put,delete)到aspx(ashx)
比如数据是这样的.
{
“deviceid”,”5″,
“tmp”,”28.5″
}
那么我在http中可以解析然后执行
insert into table_data values(“5″,”28.5″,getdate())
但是我现在要限制这个”客户端”的频率 比如 只能10s一次,否则我就输出{err:333,msg:次数太快}
常规的 我可以想到..我通过deviceid去查询数据库
select top 1 date from table_data where deviceid=”5” order by date desc
然后跟当前的datetime.now对比可以判断第二次请求跟第一次请求是否间隔了10s+
这样的话还是频繁的访问了数据库..所以 能不能用一种别的方案来解决,免除数据库交互的过程?
现在想到的是 在web中(ashx或者aspx.cs)
static dict client
用于存放ip以及datetime.now.
每次发生请求的时候我先查询key是否存在 如果存在 那么找到value并且判断时间.
if 超时
输出{err:333,msg:次数太快}
else
输出{err:0,msg:ok}
client[ip]=datetime.now;
这样的话 多个客户端一起访问 应该没什么问题吧….