为了账号安全,请及时绑定邮箱和手机立即绑定

spring Aop @args() 导致启动报错

spring Aop @args() 导致启动报错

Cats萌萌 2019-04-19 13:15:42
1.描述spring Aop @args() 导致启动报错2.自定义注解@Target({ElementType.PARAMETER}) @Retention(RetentionPolicy.RUNTIME) @Documented public @interface PropNotNull {     String[] propNames() default {}; }3.切面类@Component @Aspect public class ParameterVerify {     @Autowired     private ObjUtil objUtil;     @Around(value = "@args(com.example.obj.obj_manager.parameter_verify.prop_not_null.PropNotNull)")//环绕切面     public Object before(ProceedingJoinPoint pjp) throws Throwable {         System.out.println(1111);         Object ret = pjp.proceed();         return ret;     } }4.报错java.lang.NullPointerException: null     at org.springframework.web.filter.GenericFilterBean.init(GenericFilterBean.java:240) ~[spring-web-5.1.5.RELEASE.jar:5.1.5.RELEASE]     at org.apache.catalina.core.ApplicationFilterConfig.initFilter(ApplicationFilterConfig.java:270) ~[tomcat-embed-core-9.0.16.jar:9.0.16]     at org.apache.catalina.core.ApplicationFilterConfig.<init>(ApplicationFilterConfig.java:106) ~[tomcat-embed-core-9.0.16.jar:9.0.16]     at org.apache.catalina.core.StandardContext.filterStart(StandardContext.java:4516) [tomcat-embed-core-9.0.16.jar:9.0.16]     at org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:5162) [tomcat-embed-core-9.0.16.jar:9.0.16]     at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:183) [tomcat-embed-core-9.0.16.jar:9.0.16]     at org.apache.catalina.core.ContainerBase$StartChild.call(ContainerBase.java:1377) [tomcat-embed-core-9.0.16.jar:9.0.16]     at org.apache.catalina.core.ContainerBase$StartChild.call(ContainerBase.java:1367) [tomcat-embed-core-9.0.16.jar:9.0.16]     at java.util.concurrent.FutureTask.run(FutureTask.java:266) [na:1.8.0_172]5.措施将切点表达式中的:@args()换成@annotation就不会报错了,能正常启动了。6.请教请教各位前辈,是什么原因导致idea启动不了项目的?是不是@args这个表达式有问题?
查看完整描述

3 回答

?
梦里花落0921

TA贡献1772条经验 获得超6个赞

找到问题了,原来是只使用@args(*.*.*.*)的时候,会匹配到spring中某些被final修饰过的类(具体为什么会匹配上,不详)。
因此需要在后面加个限定条件:@Around(value = "@args(com.example.demo.prop_not_null.PropNotNul)&& within(com.example.demo..*)")。
限定包名为自己的项目中的包,这样就能避免匹配到其他东西了


查看完整回答
反对 回复 2019-05-14
  • 3 回答
  • 0 关注
  • 1243 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信