自定义注解+ResponseBodyAdvice实现部分接口的结果封装

转自 https://blog.csdn.net/liuhe2296044/article/details/81742390

 

包装前:

{"name":"王月","age":0}
包装后:

{"status":{"code":0,"name":"OK","msg":"succeed"},"result":{"name":"王月","age":0}}
实现思路:ResponseBodyAdvice+自定义注解

ResponseBodyAdvice实现类:
@ControllerAdvice
public class FocusResponseBodyAdvice implements ResponseBodyAdvice {
 
  /**
   * 在这个方法完成 "怎样封装结果集"
   */
  @Override
  public Object beforeBodyWrite(Object returnValue, MethodParameter methodParameter, MediaType mediaType, Class clas, ServerHttpRequest serverHttpRequest, ServerHttpResponse serverHttpResponse) {
    return ApiResp.ok(returnValue);
  }
 
  /**
   * 在这个方法完成 "是否对这个接口生效"  方案1.直接判断方法名 方案二2.判断哪些接口打注解[推荐]
   */
 
  @Override
  public boolean supports(MethodParameter methodParameter, Class clas) {
    AnnotatedElement annotatedElement = methodParameter.getAnnotatedElement();
    FocusAnnotation focusController = AnnotationUtils.findAnnotation(annotatedElement, FocusAnnotation.class);
    return focusController != null;
  }
}
自定义注解类:

@Target({ElementType.METHOD})
@Retention(RetentionPolicy.RUNTIME)
@Documented
public @interface FocusAnnotation {
}
基类:

public class GirlFriend {
 
  private String name;
  private int age;
 
  public String getName() {
    return name;
  }
 
  public void setName(String name) {
    this.name = name;
  }
 
  public int getAge() {
    return age;
  }
 
  public void setAge(int age) {
    this.age = age;
  }
 
}
响应包装类:

  public class ApiResp {
  public static ApiResp OK = new ApiResp(Status.OK);
 
  public static ApiResp error(Status status) {
    return new ApiResp(status);
  }
 
  public static ApiResp ok(Object result) {
    return new ApiResp(Status.OK, result);
  }
 
  private final Status status;
 
  private final Object result;
 
  public ApiResp(Status status) {
    this(status, null);
  }
 
  public ApiResp(Status status, Object result) {
    this.status = status;
    this.result = result;
  }
 
  public Status getStatus() {
    return status;
  }
 
  public Object getResult() {
    return result;
  }
}
响应类包装类2:

public class Status {
  public static Status OK = new Status(0, "OK", "succeed");
 
  private final int code;
  private final String name;
  private String msg;
 
  /**
   * @param code 错误码
   */
  public Status(int code) {
    this(code, String.valueOf(code), String.valueOf(code));
  }
 
  /**
   * @param code 错误码
   * @param name 错误的名字
   */
  public Status(int code, String name) {
    this(code, name, name);
  }
 
  /**
   * @param code 错误码
   * @param name 错误的名字
   * @param msg  错误信息,用于提示
   */
  public Status(int code, String name, String msg) {
    this.code = code;
    this.name = name;
    this.msg = msg;
  }
  
  /**
   * @return 错误码
   */
  public int getCode() {
    return code;
  }
 
  /**
   * @return 错误的名字
   */
  public String getName() {
    return name;
  }
 
  /**
   * @return 错误信息,用于提示
   */
  public String getMsg() {
    return msg;
  }
 
  /**
   * @param msg 错误信息,用于提示
   */
  public Status setMsg(String msg) {
    this.msg = msg;
    return this;
  }
 
}
Controller类:

@Controller
public class MainController {
 
    @RequestMapping(value = "/annotation",method = RequestMethod.GET)
    @ResponseBody
    @FocusAnnotation   //只有第一个加了自定义注解
    public GirlFriend sayHello(){
        GirlFriend girlFriend = new GirlFriend();
        girlFriend.setName("王月");
        return girlFriend;
    }
 
    @RequestMapping(value = "/annotation2",method = RequestMethod.GET)
    @ResponseBody
    public GirlFriend sayHello2(){
        GirlFriend girlFriend = new GirlFriend();
        girlFriend.setName("王月");
        return girlFriend;
    }
}
 
--------------------- 

要通过自定义注解和AOP来实现Spring Security配置指定接口不需要Token才能访问,可以按照以下步骤进行操作: 1. 创建一个自定义注解,例如`@NoTokenRequired`,用于标识不需要Token的接口。 ```java @Target(ElementType.METHOD) @Retention(RetentionPolicy.RUNTIME) public @interface NoTokenRequired { } ``` 2. 创建一个切面类,用于拦截带有`@NoTokenRequired`注解的方法,并跳过Spring Security的Token验证。 ```java @Aspect @Component public class TokenValidationAspect { @Before("@annotation(com.example.NoTokenRequired)") public void skipTokenValidation(JoinPoint joinPoint) { // 跳过Spring Security的Token验证逻辑 SecurityContextHolder.getContext().setAuthentication(null); } } ``` 3. 配置Spring Security,将AOP切面类添加到Spring Security的配置中。 ```java @Configuration @EnableWebSecurity public class SecurityConfig extends WebSecurityConfigurerAdapter { @Autowired private TokenValidationAspect tokenValidationAspect; @Override protected void configure(HttpSecurity http) throws Exception { http .authorizeRequests() // 配置需要Token验证的接口 .anyRequest().authenticated() .and() .csrf().disable(); // 将AOP切面类添加到Spring Security的配置中 http.addFilterBefore(tokenValidationAspect, UsernamePasswordAuthenticationFilter.class); } } ``` 4. 在需要不需要Token验证的接口上,添加`@NoTokenRequired`注解。 ```java @RestController public class ExampleController { @NoTokenRequired @GetMapping("/example") public String example() { return "This API does not require Token"; } } ``` 这样配置之后,带有`@NoTokenRequired`注解的接口将不会进行Spring Security的Token验证,即可在没有Token的情况下访问该接口。其他接口仍然需要进行Token验证。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值