实习中Zzzzz遇到问题第一时间记录下来才行,脑容量不够用了
instance关键字,判断一个实例是否是某个类的实例化,看了一下底层实现,貌似使用switch判断的,case值判断
HandlerMethodArgumentResolver自定义注解解释器,需要继承实现,包含两个方法
public class AuthResolver implements HandlerMethodArgumentResolver
//继承类实现自定义注解解释器
public boolean supportsParameter(MethodParameter methodParameter)
//判断是否需要进行下面方法的操作,可以在里面自定义需要的判断
public Object resolveArgument(
MethodParameter methodParameter,
@Nullable ModelAndViewContainer modelAndViewContainer,
NativeWebRequest nativeWebRequest,
@Nullable WebDataBinderFactory webDataBinderFactory)
throws Exception
//具体逻辑实现,返回值是在控制器使用该注解的对象,给使用该注解的对象注入返回值。
看了十几分钟别人的解释终于明白了这个东西是干嘛的怎么用,他可以实现自定义注解的解释和操作,如我需要定义一个@LoginUser注解,用来注解我的对象:
public RspVo saveAdmin(@LoginUser AdminEntity Loginuser, @RequestBody AdminEntity body)
//需要一个AdminEntity对象Loginuser,使用LoginUser注解获得
@Target(ElementType.PARAMETER)
@Retention(RetentionPolicy.RUNTIME)
public @interface LoginUser {
}
//定义一个注解类
使用@LoginUser 注解首先会到supportsParameter方法判断是否需要进行resolveArgument操作,返回true则进行,在resolveArgument方法里返回一个需要的对象,即完成对象注入
补充:遇到了几个问题,一个是配置,查了一下有两种方法,在配置好自定义注解解释器后:
1.新建两个类配置
@Configuration
public class WebMvcConfig extends WebMvcConfigurerAdapter {
@Override
public void addArgumentResolvers(List<HandlerMethodArgumentResolver> argumentResolvers) {
super.addArgumentResolvers(argumentResolvers);
argumentResolvers.add(new ManagerReslover());
}
}
@Configuration
public class WebConfig extends WebMvcConfigurationSupport {
@Override
protected void addArgumentResolvers(List<HandlerMethodArgumentResolver> argumentResolvers) {
// 注册JsonPathArgumentResolver的参数分解器
argumentResolvers.add(new AuthResolver(adminEntityRepository,loginRecordEntityRepository));
}
}
2.在启动类那里继承WebMvcConfigurerAdapter
再加入方法在启动类里
@Override
public void addArgumentResolvers(List<HandlerMethodArgumentResolver> argumentResolvers) {
super.addArgumentResolvers(argumentResolvers);
argumentResolvers.add(new ManagerReslover());
}
这里我用springboot的时候又遇到几个问题,我在解释器内配置jpa的Repository的时候@Autowired注入不了,导致Repository为null,
解决:在上面配置类那里配置Repository,注册那里加上需要的Repository作为参数传进解释器内