1.背景
在spring请求时,要对参数进行检查,以前一直使用如下方式来获取参数,在参数特别多的时候,代码很不简洁。
string userid= request.getparameter("userid");
后来使用注解@requestparam代码整洁了好多
@requestparam(value = "userid",required=true) string userid
后来对于参数比较多的情况,使用一个bean来接收请求参数
@requestmapping(value="/saveuser")public string saveuser(user user) {}
对于比较复杂,有层级关系情况,使用注解@requestbody实现
public string setuser(@requestbody string userinfo) { //使用fastjson转换为实体类}
不管使用以上的哪种方式都要对参数进行校验,如果一个个参数的检查是否为空,检查边界范围,会导致代码很多。使用@valid注解来对参数进行校验能让代码更整洁。
2.使用本文以实体类接收请求参数为例简单讲解,validation一共有hibernate-validator,javax.validation和spring-validator三种注解,本文主要是简单讲解一下javax.validation的使用
@requestmapping(value="/saveuser")@responsebodypublic jsonobject saveuser(@valid user user, bindingresult result){ jsonobject jsonobject = new jsonobject(); //判断是否检验错误信息 if(result.haserrors()){ //取出第一条错误信息返回 list<fielderror> list = result.getfielderrors(); string errormessage = collectionutils.isempty(list)? "参数错误!":list.get(0).getdefaultmessage(); jsonobject.put("errormessage",errormessage ); return jsonobject; } //saveuser保存用户信息模块省略 jsonobject.put("errormessage","success"); return jsonobject; }
//使用lombok@datapublic class user implements serializable{ @notnull(message = "用户id不能为空") @pattern(regexp="^\\d{12}$",message = "用户id非法") private string userid; private string username; private int age;}
使用@valid注解进行参数检查
在没有使用bindingresult时,程序会抛出空指针等异常信息,不能返回自定义信息,网上查了一下需要使用bindingresult来处理error信息,自定义返回错误数据。@notnull,@pattern,@size,@max,@min,@digits是我在项目中经常使用的注解以上就是java开发中spring参数的传递和检验的详细内容。