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

三河市建设厅公示网站四川最好的网络优化公司

三河市建设厅公示网站,四川最好的网络优化公司,山西 网站建设,购物网站建设需要公司营业执照吗一、背景 在给第三方提供接口时,我们需要对接口进行验签。具体来说,当外部系统调用我们的接口时,请求中需要携带一个签名,我们接收到请求后,会解析数据并校验签名是否正确,以确保请求的合法性和安全性。 为了在不同项目中方便地使用这一功能,我们将签名校验规则封装成一…

一、背景

在给第三方提供接口时,我们需要对接口进行验签。具体来说,当外部系统调用我们的接口时,请求中需要携带一个签名,我们接收到请求后,会解析数据并校验签名是否正确,以确保请求的合法性和安全性。

为了在不同项目中方便地使用这一功能,我们将签名校验规则封装成一个工具包。使用方只需通过简单的注解即可轻松集成验签功能,无需重复编写验签逻辑,从而提高开发效率并确保一致性。

二、实现原理

  1. 使用AOP来拦截方法
  2. 获取参数值进行组装、校验签名是否一致

三、设计思路

通过俩个注解进行标记所需要进行验签的方法

@Target(ElementType.METHOD)
@Retention(RetentionPolicy.RUNTIME)
public @interface SignatureChecker {// 服务CodeString serviceCode() default SignatureConst.EMPTY_STR;// 签名生成密钥String secretKey() default SignatureConst.EMPTY_STR;// 签名过期时间,单位为分钟int expireMinutes() default -1;// 默认为true,表示需要验证签名boolean required() default true;// 返回值类型String returnType() default SignatureConst.DEFAULT_RETURN_TYPE;}

serviceCode:服务编码,进行区分不同的服务/业务
secretKey:双方约定好的密钥,进行生成签名,可以写在配置文件中。
expireMinutes:标识签名有效时长,默认5分钟,可以配置文件中进行全局修改。

@Target(ElementType.PARAMETER)
@Retention(RetentionPolicy.RUNTIME)
public @interface SignatureParam {// 0:标识serviceCode 1:标识请求参数SignatureParamTypeEnum type() default SignatureParamTypeEnum.PARAMS;String requestIdField() default SignatureConst.EMPTY_STR;String timestampField() default SignatureConst.EMPTY_STR;String signatureField() default SignatureConst.EMPTY_STR;}

对于不同的请求实体,可能对应的字段名不相同,所以我们需要使用一个注解进行标注当前实体验签字段的名称。

当签名字段发生变化时,可以使用requestIdField、timestampField、signatureField 字段进行指定。

四、代码

4.1 代码结构

4.2 详细代码

4.2.1 SignatureChecker.class
import org.tao.consts.SignatureConst;import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;@Target(ElementType.METHOD)
@Retention(RetentionPolicy.RUNTIME)
public @interface SignatureChecker {// 服务CodeString serviceCode() default SignatureConst.EMPTY_STR;// 签名生成密钥String secretKey() default SignatureConst.EMPTY_STR;// 签名过期时间,单位为分钟int expireMinutes() default -1;// 默认为true,表示需要验证签名boolean required() default true;// 返回值类型String returnType() default SignatureConst.DEFAULT_RETURN_TYPE;}
4.2.2 SignatureParam.class
import org.tao.consts.SignatureConst;
import org.tao.enums.SignatureParamTypeEnum;import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;@Target(ElementType.PARAMETER)
@Retention(RetentionPolicy.RUNTIME)
public @interface SignatureParam {// 0:标识serviceCode 1:标识请求参数SignatureParamTypeEnum type() default SignatureParamTypeEnum.PARAMS;String requestIdField() default SignatureConst.EMPTY_STR;String timestampField() default SignatureConst.EMPTY_STR;String signatureField() default SignatureConst.EMPTY_STR;}
4.2.3 SignatureAspect.class

import com.alibaba.fastjson2.JSON;
import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.annotation.Around;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.reflect.MethodSignature;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Component;
import org.springframework.util.StringUtils;
import org.tao.anno.SignatureChecker;
import org.tao.anno.SignatureParam;
import org.tao.config.SignatureProperties;
import org.tao.consts.SignatureConst;
import org.tao.enums.SignatureParamTypeEnum;
import org.tao.exception.SignatureValidationException;
import org.tao.utils.SignatureUtil;import javax.annotation.Resource;
import java.lang.annotation.Annotation;
import java.lang.reflect.Method;
import java.util.Map;@Aspect
@Component
public class SignatureAspect {private static final Logger logger = LoggerFactory.getLogger(SignatureAspect.class);@Resourceprivate SignatureProperties signatureProperties;@Around("@annotation(org.tao.anno.SignatureChecker) " +"&& (@annotation(org.springframework.web.bind.annotation.PostMapping) || @annotation(org.springframework.web.bind.annotation.RequestMapping))")public Object validateSignature(ProceedingJoinPoint joinPoint) throws Throwable {MethodSignature signature = (MethodSignature) joinPoint.getSignature();Method method = signature.getMethod();Map<String, Object> paramMap = null;String serviceCode = null;Object[] args = joinPoint.getArgs();Annotation[][] parameterAnnotations = method.getParameterAnnotations();SignatureChecker s
http://www.dtcms.com/wzjs/302432.html

相关文章:

  • 做白酒网站百度统计工具
  • 科技公司网站设计欣赏大数据推广公司
  • 网站seo排名培训seo
  • 上海信息技术做网站2023年国家免费技能培训
  • 线上咨询上门服务网站建设方案网站收录是什么意思
  • 武功做网站品牌运营具体做什么
  • 公司如何做网站建设网络推广网络营销软件
  • 音乐网站怎么做社交的长沙百度网站排名优化
  • 网站做推广团队百度快照和广告的区别
  • 仿win8 网站模版国外域名注册网站
  • 十堰学网站建设培训班近期的重大新闻
  • 做建材加盟什么网站好门户网站
  • 做网站的服务器哪个系统好泰州seo推广公司
  • 网页qq登陆手机版网址南宁百度首页优化
  • 新疆生产建设兵团教育局网站web网址
  • 电信100m光纤做网站代发关键词包收录
  • 查询网站用什么做的ks免费刷粉网站推广马上刷
  • 技术支持 湘潭网站建设网络销售有哪些
  • 山西建设机械网站首页优化师助理
  • 做网站在阿里云买什么软件人力资源培训机构
  • 亚洲做性视频网站北京学校线上教学
  • 网站推广的方式有哪几种关键词排名工具
  • 网站建设盈利模式北京整站线上推广优化
  • 专门做ppt的网站自动外链网址
  • 广东深圳市宝安区疫情最新情况福州短视频seo网站
  • 网站编辑简历百度关键词排名批量查询
  • 邵阳网站建设上科互联网络营销的概念及特点
  • 怎么做网站数据分析正规百度推广
  • wordpress网站都有哪些绍兴百度seo排名
  • 买的虚拟主机怎么做网站5118