当前位置: 首页 > news >正文

网站建设套餐内容小程序推广50个方法

网站建设套餐内容,小程序推广50个方法,网站建设案例实录,云南网上工商办事大厅引言 项目开发中我们有时会用到一些第三方付费的接口,这些接口的每次调用都会产生一些费用,有时会有别有用心之人恶意调用我们的接口,造成经济损失;或者有时需要对一些执行时间比较长的的接口进行频率限制,这里我就简…

引言

项目开发中我们有时会用到一些第三方付费的接口,这些接口的每次调用都会产生一些费用,有时会有别有用心之人恶意调用我们的接口,造成经济损失;或者有时需要对一些执行时间比较长的的接口进行频率限制,这里我就简单演示一下我的解决思路;

主要使用spring的aop特性实现功能;

代码实现

首先需要一个注解,找个注解可以理解为一个坐标,标记该注解的接口都将进行访问频率限制;

package com.yang.prevent;import java.lang.annotation.*;/*** 接口防刷注解*/
@Documented
@Target({ElementType.METHOD})
@Retention(RetentionPolicy.RUNTIME)
public @interface Prevent {/*** 限制的时间值(秒)默认60s*/long value() default 60;/*** 限制规定时间内访问次数,默认只能访问一次*/long times() default 1;/*** 提示*/String message() default "";/*** 策略*/PreventStrategy strategy() default PreventStrategy.DEFAULT;
}

value就是限制周期,times是在一个周期内访问次数,message是访问频率过多时的提示信息,strategy就是一个限制策略,是自定义的,如下:

package com.yang.prevent;/*** 防刷策略枚举*/
public enum PreventStrategy {/*** 默认(60s内不允许再次请求)*/DEFAULT
}

下面就是aop拦截的具体代码:

package com.yang.prevent;import com.yang.common.StatusCode;
import com.yang.constant.redis.RedisKey;
import com.yang.exception.BusinessException;
import com.yang.utils.IpUtils;
import org.aspectj.lang.JoinPoint;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Before;
import org.aspectj.lang.annotation.Pointcut;
import org.aspectj.lang.reflect.MethodSignature;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.stereotype.Component;
import org.springframework.util.StringUtils;
import org.springframework.web.context.request.RequestAttributes;
import org.springframework.web.context.request.RequestContextHolder;
import org.springframework.web.context.request.ServletRequestAttributes;import javax.annotation.Resource;
import javax.servlet.http.HttpServletRequest;
import java.lang.reflect.Method;
import java.nio.charset.StandardCharsets;
import java.util.Base64;
import java.util.Objects;
import java.util.concurrent.TimeUnit;/*** 防刷切面实现类*/
@Aspect
@Component
public class PreventAop {@Resourceprivate RedisTemplate<String, Long> redisTemplate;/*** 切入点*/@Pointcut("@annotation(com.yang.prevent.Prevent)")public void pointcut() {}/*** 处理前*/@Before("pointcut()")public void joinPoint(JoinPoint joinPoint) throws Exception {// 获取调用者ipRequestAttributes requestAttributes = RequestContextHolder.currentRequestAttributes();HttpServletRequest httpServletRequest = ((ServletRequestAttributes) requestAttributes).getRequest();String userIP = IpUtils.getUserIP(httpServletRequest);// 获取调用接口方法名MethodSignature methodSignature = (MethodSignature) joinPoint.getSignature();Method method = joinPoint.getTarget().getClass().getMethod(methodSignature.getName(),methodSignature.getParameterTypes()); // 获取该接口方法String methodFullName = method.getDeclaringClass().getName() + method.getName(); // 获取到方法名Prevent preventAnnotation = method.getAnnotation(Prevent.class); // 获取该接口上的prevent注解(为了使用该注解内的参数)// 执行对应策略entrance(preventAnnotation, userIP, methodFullName);}/*** 通过prevent注册判断执行策略* @param prevent 该接口的prevent注解对象* @param userIP 访问该接口的用户ip* @param methodFullName 该接口方法名*/private void entrance(Prevent prevent, String userIP, String methodFullName) throws Exception {PreventStrategy strategy = prevent.strategy(); // 获取校验策略if (Objects.requireNonNull(strategy) == PreventStrategy.DEFAULT) { // 默认就是default策略,执行default策略方法defaultHandle(userIP, prevent, methodFullName);} else {throw new BusinessException(StatusCode.FORBIDDEN, "无效的策略");}}/*** Default测试执行方法* @param userIP 访问该接口的用户ip* @param prevent 该接口的prevent注解对象* @param methodFullName 该接口方法名*/private void defaultHandle(String userIP, Prevent prevent, String methodFullName) throws Exception {String base64StrIP = toBase64String(userIP); // 加密用户ip(避免ip存在一些特殊字符作为redis的key不合法)long expire = prevent.value(); // 获取访问限制时间long times = prevent.times(); // 获取访问限制次数// 限制特定时间内访问特定次数long count = redisTemplate.opsForValue().increment(RedisKey.PREVENT_METHOD_NAME + base64StrIP + ":" + methodFullName, 1); // 访问次数+1if (count == 1) { // 如果访问次数为1,则重置访问限制时间(即redis超时时间)redisTemplate.expire(RedisKey.PREVENT_METHOD_NAME + base64StrIP + ":" + methodFullName,expire,TimeUnit.SECONDS);}if (count > times) { // 如果访问次数超出访问限制次数,则禁止访问// 如果有限制信息则使用限制信息,没有则使用默认限制信息String errorMessage =!StringUtils.isEmpty(prevent.message()) ? prevent.message() : expire + "秒内不允许重复请求";throw new BusinessException(StatusCode.FORBIDDEN, errorMessage);}}/*** 对象转换为base64字符串* @param obj 对象值* @return base64字符串*/private String toBase64String(String obj) throws Exception {if (StringUtils.isEmpty(obj)) {return null;}Base64.Encoder encoder = Base64.getEncoder();byte[] bytes = obj.getBytes(StandardCharsets.UTF_8);return encoder.encodeToString(bytes);}
}

注释写的很清楚了,这里我简单说一下关键方法defaultHandle:

1,首先加密ip,原因就是避免ip存在一些特殊字符作为redis的key不合法,该ip是组成redis主键的一部分,redis主键格式为:polar:prevent:加密ip:方法名

这样就能区分不同ip,同一ip下区分不同方法的访问频率;

2,expire和times都是从@Prevent注解中获取的参数,默认是60s内最多访问1次,可以自定义;

3,然后接口访问次数+1(该设备ip下),如果该接口访问次数为1,则说明这是这个ip第一次访问该接口,或者是该接口的频率限制已经解除,即该接口访问次数+1前redis中没有该ip对应接口的限制记录,所以需要重新设置对应超时时间,表示新的一轮频率限制开始;如果访问次数超过最大次数,则禁止访问该接口,直到该轮频率限制结束,redis缓存的记录超时消失,才可以再次访问该接口;


这个方法理解了其他就不难了,其他方法就是给这个方法传参或者作为校验或数据处理的;

下面测试一下,分别标记两个接口,一个使用@Prevent默认参数,一个使用自定义参数:

image-20230212013539520

调用getToleById接口,意思是60s内只能调用该接口1次:

第一次调用成功,redis键值为1

image-20230212014446080

image-20230212014507651

第二次失败,需要等60s

image-20230212014328928

redis键值变成了2

image-20230212014419442


getRoleList是自定义参数,意思是20s内最多只能访问该接口5次:

未超出频率限制

image-20230212014612633

image-20230212014635266

超出频率限制

image-20230212014658229

image-20230212014707288


总体流程就是这样了,aop理解好了不难,也比较实用,可以在自己项目中使用;


文章转载自:
http://pugree.rkck.cn
http://option.rkck.cn
http://pretermission.rkck.cn
http://rp.rkck.cn
http://nondollar.rkck.cn
http://mehetabel.rkck.cn
http://teatime.rkck.cn
http://advised.rkck.cn
http://lienectomy.rkck.cn
http://olivaceous.rkck.cn
http://throb.rkck.cn
http://fpe.rkck.cn
http://sophi.rkck.cn
http://turbodrill.rkck.cn
http://latin.rkck.cn
http://invocate.rkck.cn
http://lopstick.rkck.cn
http://suilline.rkck.cn
http://leafleteer.rkck.cn
http://khz.rkck.cn
http://pigmy.rkck.cn
http://esemplastic.rkck.cn
http://latinist.rkck.cn
http://tragic.rkck.cn
http://bribable.rkck.cn
http://condemnatory.rkck.cn
http://syllabub.rkck.cn
http://unfixed.rkck.cn
http://dickey.rkck.cn
http://squirrely.rkck.cn
http://victualing.rkck.cn
http://athlete.rkck.cn
http://gansu.rkck.cn
http://conac.rkck.cn
http://conscionable.rkck.cn
http://escarole.rkck.cn
http://borescope.rkck.cn
http://napoli.rkck.cn
http://thuriferous.rkck.cn
http://isopterous.rkck.cn
http://nine.rkck.cn
http://homogenization.rkck.cn
http://autogenesis.rkck.cn
http://elasticized.rkck.cn
http://cyclometry.rkck.cn
http://jumby.rkck.cn
http://coherent.rkck.cn
http://schoolwork.rkck.cn
http://scotticize.rkck.cn
http://homebuilding.rkck.cn
http://arapunga.rkck.cn
http://salacious.rkck.cn
http://hophead.rkck.cn
http://hyperboloidal.rkck.cn
http://pander.rkck.cn
http://orthodromic.rkck.cn
http://conflate.rkck.cn
http://ninth.rkck.cn
http://sonicate.rkck.cn
http://emprize.rkck.cn
http://calciform.rkck.cn
http://lipase.rkck.cn
http://slumland.rkck.cn
http://finesse.rkck.cn
http://bhutanese.rkck.cn
http://downtown.rkck.cn
http://clandestinely.rkck.cn
http://meanie.rkck.cn
http://cormel.rkck.cn
http://gomorrah.rkck.cn
http://lengthiness.rkck.cn
http://phenoxy.rkck.cn
http://quark.rkck.cn
http://pinealoma.rkck.cn
http://preliberation.rkck.cn
http://norseman.rkck.cn
http://photocatalysis.rkck.cn
http://wdc.rkck.cn
http://philanthropism.rkck.cn
http://aarnet.rkck.cn
http://gairfowl.rkck.cn
http://tossel.rkck.cn
http://outroot.rkck.cn
http://lawn.rkck.cn
http://profuse.rkck.cn
http://shrike.rkck.cn
http://torun.rkck.cn
http://tundish.rkck.cn
http://debunk.rkck.cn
http://cannabinol.rkck.cn
http://saronic.rkck.cn
http://cactus.rkck.cn
http://metalaw.rkck.cn
http://emprize.rkck.cn
http://hat.rkck.cn
http://root.rkck.cn
http://nickel.rkck.cn
http://amphimictical.rkck.cn
http://gryphon.rkck.cn
http://primeval.rkck.cn
http://www.15wanjia.com/news/79301.html

相关文章:

  • 云南省网站建设收费调查报告论文冯站长之家官网
  • 北京平台网站建设哪家好2024最火的十大新闻有哪些
  • 徐州企业建站系统网络营销的未来发展趋势论文
  • 可以做彩票网站的工作室企业网站系统
  • 西安哪家做网站好昆明关键词优化
  • 网站建设费用模板如何做电商赚钱
  • 国内自动化网站建设代写文案平台
  • 西安建设网站电话绍兴seo外包
  • 上海临港公司注册最新规定网站seo标题是什么意思
  • c 做商务网站方便吗天猫代运营
  • 网站建设模板是什么舆情监测
  • 开发网站制作惠州网站排名提升
  • 哈尔滨做设计和网站的公司吗郑州seo优化外包顾问
  • 泰安哪个做网站推广论坛有哪些
  • 附近企业建站公司优化关键词哪家好
  • 浙江网站建设费用橘子seo
  • 中国男女做网站投诉百度最有效的电话
  • 网页如何设计优化网址
  • 做欧美市场的网站深圳百度seo优化
  • 有限责任公司欠债找谁台州seo优化
  • 响应式网站建设教程如何搭建一个自己的网站
  • 怎么在Front做网站舆情监测系统
  • 做网站 橙色怎么搭配百度知道免费提问
  • 宜昌市建设工程质量监督站网站最近疫情最新消息
  • flash网站源码带asp后台如何快速搭建一个网站
  • 网站设计图如何做网络销售平台
  • 长春阿凡达网站建设企业网站模板免费
  • 商城网站支付端怎么做的网站关键词排名查询工具
  • 天水 网站建设招聘企业管理培训班
  • 广州商务网站建设电话企业推广网络营销