使用Spring Aop验证方法参数是否合法
先定义两个注解类ValidateGroup 和 ValidateFiled
ValidateGroup .java
- package com.zf.ann;
- import java.lang.annotation.ElementType;
- import java.lang.annotation.Retention;
- import java.lang.annotation.RetentionPolicy;
- import java.lang.annotation.Target;
- @Retention(RetentionPolicy.RUNTIME)
- @Target(ElementType.METHOD)
- public @interface ValidateGroup {
- public ValidateFiled[] fileds() ;
- }
ValidateFiled.java
- package com.zf.ann;
- import java.lang.annotation.ElementType;
- import java.lang.annotation.Retention;
- import java.lang.annotation.RetentionPolicy;
- import java.lang.annotation.Target;
- @Retention(RetentionPolicy.RUNTIME)
- @Target(ElementType.METHOD)
- public @interface ValidateFiled {
- /**
- * 参数索引位置
- */
- public int index() default -1 ;
- /**
- * 如果参数是基本数据类型或String ,就不用指定该参数,如果参数是对象,要验证对象里面某个属性,就用该参数指定属性名
- */
- public String filedName() default "" ;
- /**
- * 正则验证
- */
- public String regStr() default "";
- /**
- * 是否能为空 , 为true表示不能为空 , false表示能够为空
- */
- public boolean notNull() default false;
- /**
- * 是否能为空 , 为true表示不能为空 , false表示能够为空
- */
- public int maxLen() default -1 ;
- /**
- * 最小长度 , 用户验证字符串
- */
- public int minLen() default -1 ;
- /**
- *最大值 ,用于验证数字类型数据
- */
- public int maxVal() default -1 ;
- /**
- *最小值 ,用于验证数值类型数据
- */
- public int minVal() default -1 ;
- }
注解处理类
ValidateAspectHandel.java
- package com.zf.aspet;
- import java.lang.annotation.Annotation;
- import java.lang.reflect.InvocationTargetException;
- import java.lang.reflect.Method;
- import org.aspectj.lang.ProceedingJoinPoint;
- import org.aspectj.lang.annotation.Around;
- import org.aspectj.lang.annotation.Aspect;
- import org.springframework.stereotype.Component;
- import org.springframework.web.servlet.ModelAndView;
- import com.zf.ann.ValidateFiled;
- import com.zf.ann.ValidateGroup;
- /**
- * 验证注解处理类
- * @author zhoufeng
- */
- @Component
- @Aspect
- public class ValidateAspectHandel {
- /**
- * 使用AOP对使用了ValidateGroup的方法进行代理校验
- * @throws Throwable
- */
- @SuppressWarnings({ "finally", "rawtypes" })
- @Around("@annotation(com.zf.ann.ValidateGroup)")
- public Object validateAround(ProceedingJoinPoint joinPoint) throws Throwable {
- boolean flag = false ;
- ValidateGroup an = null;
- Object[] args = null ;
- Method method = null;
- Object target = null ;
- String methodName = null;
- try{
- methodName = joinPoint.getSignature().getName();
- target = joinPoint.getTarget();
- method = getMethodByClassAndName(target.getClass(), methodName); //得到拦截的方法
- args = joinPoint.getArgs(); //方法的参数
- an = (ValidateGroup)getAnnotationByMethod(method ,ValidateGroup.class );
- flag = validateFiled(an.fileds() , args);
- }catch(Exception e){
- flag = false;
- }finally{
- if(flag){
- System.out.println("验证通过");
- return joinPoint.proceed();
- }else{ //这里使用了Spring MVC ,所有返回值应该为Strng或ModelAndView ,如果是用Struts2,直接返回一个String的resutl就行了
- System.out.println("验证未通过");
- Class returnType = method.getReturnType(); //得到方法返回值类型
- if(returnType == String.class){ //如果返回值为Stirng
- return "/error.jsp"; //返回错误页面
- }else if(returnType == ModelAndView.class){
- return new ModelAndView("/error.jsp");//返回错误页面
- }else{ //当使用Ajax的时候 可能会出现这种情况
- return null ;
- }
- }
- }
- }
- /**
- * 验证参数是否合法
- */
- public boolean validateFiled( ValidateFiled[] valiedatefiles , Object[] args) throws SecurityException, IllegalArgumentException, NoSuchMethodException, IllegalAccessException, InvocationTargetException{
- for (ValidateFiled validateFiled : valiedatefiles) {
- Object arg = null;
- if("".equals(validateFiled.filedName()) ){
- arg = args[validateFiled.index()];
- }else{
- arg = getFieldByObjectAndFileName(args[validateFiled.index()] ,
- validateFiled.filedName() );
- }
- if(validateFiled.notNull()){ //判断参数是否为空
- if(arg == null )
- return false;
- }else{ //如果该参数能够为空,并且当参数为空时,就不用判断后面的了 ,直接返回true
- if(arg == null )
- return true;
- }
- if(validateFiled.maxLen() > 0){ //判断字符串最大长度
- if(((String)arg).length() > validateFiled.maxLen())
- return false;
- }
- if(validateFiled.minLen() > 0){ //判断字符串最小长度
- if(((String)arg).length() < validateFiled.minLen())
- return false;
- }
- if(validateFiled.maxVal() != -1){ //判断数值最大值
- if( (Integer)arg > validateFiled.maxVal())
- return false;
- }
- if(validateFiled.minVal() != -1){ //判断数值最小值
- if((Integer)arg < validateFiled.minVal())
- return false;
- }
- if(!"".equals(validateFiled.regStr())){ //判断正则
- if(arg instanceof String){
- if(!((String)arg).matches(validateFiled.regStr()))
- return false;
- }else{
- return false;
- }
- }
- }
- return true;
- }
- /**
- * 根据对象和属性名得到 属性
- */
- public Object getFieldByObjectAndFileName(Object targetObj , String fileName) throws SecurityException, NoSuchMethodException, IllegalArgumentException, IllegalAccessException, InvocationTargetException{
- String tmp[] = fileName.split("\\.");
- Object arg = targetObj ;
- for (int i = 0; i < tmp.length; i++) {
- Method methdo = arg.getClass().
- getMethod(getGetterNameByFiledName(tmp[i]));
- arg = methdo.invoke(arg);
- }
- return arg ;
- }
- /**
- * 根据属性名 得到该属性的getter方法名
- */
- public String getGetterNameByFiledName(String fieldName){
- return "get" + fieldName.substring(0 ,1).toUpperCase() + fieldName.substring(1) ;
- }
- /**
- * 根据目标方法和注解类型 得到该目标方法的指定注解
- */
- public Annotation getAnnotationByMethod(Method method , Class annoClass){
- Annotation all[] = method.getAnnotations();
- for (Annotation annotation : all) {
- if (annotation.annotationType() == annoClass) {
- return annotation;
- }
- }
- return null;
- }
- /**
- * 根据类和方法名得到方法
- */
- public Method getMethodByClassAndName(Class c , String methodName){
- Method[] methods = c.getDeclaredMethods();
- for (Method method : methods) {
- if(method.getName().equals(methodName)){
- return method ;
- }
- }
- return null;
- }
- }
需要验证参数的Control方法
- package com.zf.service;
- import org.springframework.stereotype.Controller;
- import org.springframework.web.bind.annotation.RequestMapping;
- import org.springframework.web.servlet.ModelAndView;
- import com.zf.ann.ValidateFiled;
- import com.zf.ann.ValidateGroup;
- import com.zf.vo.Person;
- @Controller("PersonControl")
- public class PersonControl {
- //下面方法 ,是需要验证参数的方法
- @ValidateGroup(fileds = {
- //index=0 表示下面方法的第一个参数,也就是person nutNull=true 表示不能为空
- @ValidateFiled(index=0 , notNull=true ) ,
- //index=0 表示第一个参数 filedName表示该参数的一个属性 ,也就是person.id 最小值为3 也就是 person.id 最小值为3
- @ValidateFiled(index=0 , notNull=true , filedName="id" , minVal = 3) ,
- //表示第一个参数的name 也就是person.name属性最大长度为10,最小长度为3
- @ValidateFiled(index=0 , notNull=true , filedName="name" , maxLen = 10 , minLen = 3 ) ,
- //index=1 表示第二个参数最大长度为5,最小长度为2
- @ValidateFiled(index=1 , notNull=true , maxLen = 5 , minLen = 2 ) ,
- @ValidateFiled(index=2 , notNull=true , maxVal = 100 , minVal = 18),
- @ValidateFiled(index=3 , notNull=false , regStr= "^\\w+@\\w+\\.com$" )
- })
- @RequestMapping("savePerson")
- public ModelAndView savePerson(Person person , String name , int age , String email){
- ModelAndView mav = new ModelAndView("/index.jsp");
- System.out.println("addPerson()方法调用成功!");
- return mav ; //返回index.jsp视图
- }
- }
application.xml配置
测试
- package com.zf.test;
- import org.springframework.context.ApplicationContext;
- import org.springframework.context.support.ClassPathXmlApplicationContext;
- import com.zf.service.PersonControl;
- import com.zf.vo.Person;
- public class PersonTest {
- public static void main(String[] args) {
- ApplicationContext ac = new ClassPathXmlApplicationContext("applicationContext.xml");
- PersonControl ps = (PersonControl) ac.getBean("PersonControl"); //测试
- ps.savePerson(new Person(3, "qqq") , "sss" , 100 , "243970446@qq.com");
- }
- }
- <?xml version="1.0" encoding="UTF-8"?>
- <beans xmlns="http://www.springframework.org/schema/beans"
- xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:p="http://www.springframework.org/schema/p"
- xmlns:aop="http://www.springframework.org/schema/aop" xmlns:tx="http://www.springframework.org/schema/tx"
- xmlns:context="http://www.springframework.org/schema/context"
- xsi:schemaLocation="http://www.springframework.org/schema/beans
- http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
- http://www.springframework.org/schema/tx
- http://www.springframework.org/schema/tx/spring-tx-3.0.xsd
- http://www.springframework.org/schema/aop
- http://www.springframework.org/schema/aop/spring-aop-3.0.xsd
- http://www.springframework.org/schema/context
- http://www.springframework.org/schema/context/spring-context-3.0.xsd">
- <context:component-scan base-package="com.*"></context:component-scan>
- <aop:aspectj-autoproxy proxy-target-class="true"></aop:aspectj-autoproxy>
- </beans>
使用Spring Aop验证方法参数是否合法的更多相关文章
- 使用SpringAop 验证方法参数是否合法
(原文地址:http://blog.csdn.net/is_zhoufeng/article/details/7683194) 1.依赖包 aspectjweaver.jar 其中Maven的配 ...
- Spring MVC控制器方法参数类型
HttpServletRequest Spring会自动将 Servlet API 作为参数传过来 HttpServletResponse InputStream 相当于request.getInpu ...
- Spring AOP获取方法的参数名称和参数值
aop配置: <aop:aspectj-autoproxy expose-proxy="true" /> @Before(value = "execution ...
- Spring AOP执行方法
execution(* springinaction.springidol.Instrument.play(..)) * 代表返回为任意类型 springinaction.springidol.I ...
- Spring AOP实现 Bean字段合法性校验
使用SpringAop 验证方法参数是否合法 先定义两个注解类ValidateGroup 和 ValidateFiled ValidateGroup .java package com.zf.an ...
- Java获取方法参数名、Spring SpEL解析
@Test public void testParse() { //表达式解析 ExpressionParser expressionParser = new SpelExpressionParser ...
- 如何在 Spring/Spring Boot 中做参数校验?你需要了解的都在这里!
本文为作者原创,如需转载请在文首著名地址,公众号转载请申请开白. springboot-guide : 适合新手入门以及有经验的开发人员查阅的 Spring Boot 教程(业余时间维护中,欢迎一起维 ...
- 如何在 Spring/Spring Boot 中做参数校验
数据的校验的重要性就不用说了,即使在前端对数据进行校验的情况下,我们还是要对传入后端的数据再进行一遍校验,避免用户绕过浏览器直接通过一些 HTTP 工具直接向后端请求一些违法数据. 本文结合自己在项目 ...
- Spring5.0源码学习系列之Spring AOP简述
前言介绍 附录:Spring源码学习专栏 在前面章节的学习中,我们对Spring框架的IOC实现源码有了一定的了解,接着本文继续学习Springframework一个核心的技术点AOP技术. 在学习S ...
随机推荐
- POJ 2886 Who Gets the Most Candies?
思路: 对于 k 位置的 孩子,他的 数字是 +num 那么因为他自己本身是要被踢走的,所以相对位置 为k= k+num-1 如果数字是 -num,那么按正着数就没影响,k=k-num.线段树存储当前 ...
- Codeforces Round #257 (Div. 1) (Codeforces 449B)
题意:给力一张无向图,有一些边是正常道路,有一些边是铁路,问最多能删除几条铁路使得所有点到首都(编号为1)的最短路长度不变. 思路:求不能删除的铁路数,总数减掉就是答案.先求出首都到所有点的最短路,求 ...
- ASP.NET MVC过滤器(一)
MVC过滤器是加在 Controller 或 Action 上的一种 Attribute,通过过滤器,MVC 网站在处理用户请求时,可以处理一些附加的操作,如:用户权限验证.系统日志.异常处理.缓存等 ...
- ASP.NET MVC 基于角色的权限控制系统的示例教程
上一次在 .NET MVC 用户权限管理示例教程中讲解了ASP.NET MVC 通过AuthorizeAttribute类的OnAuthorization方法讲解了粗粒度控制权限的方法,接下来讲解基于 ...
- Struts2 的验证
概述 一个健壮的 web 应用程序必须确保用户输入是合法.有效的. Struts2 的输入验证 –基于 XWork Validation Framework 的声明式验证:Struts2 提供了一些基 ...
- Unity安卓连接profile调试
通过USB ADB 1.从Unity中Export Android 工程的时候一定要勾选 Development Build,autoconnect profiler 2.cmd进入adb的目录(打开 ...
- [Windows驱动]流媒体驱动开发
从Windows98开始,Windows流媒体驱动遵循Windows Driver Model(WDM)模型并使用Kernel Streaming(KS)组件.Kernel Streaming(KS) ...
- 图解Nosql(hbase)与传统数据库的区别
图解Nosql(hbase)与传统数据库的区别http://www.aboutyun.com/thread-7804-1-1.html(出处: about云开发) 问题导读:1.nosql数据库能否删 ...
- Access 中数据库操作时提示from子句语法错误
问题:如果在Access 中数据库操作时提示from子句语法错误原因:语句中某一单词为Access中的关键字.如:select * from user.其中user就是一关键字.解决:用中括号[]将其 ...
- 又见蒙特卡洛——python模拟解决三门问题
三门问题很有意思,wiki用不同方法将原理讲的很透彻了,我跟喜欢其中这种理解方式:无论参赛者开始的选择如何,在被主持人问到是否更换时都选择更换.如果参赛者先选中山羊,换之后百分之百赢:如果参赛者先选中 ...