对前台传过来的实体是否为空 进行为空校验的N种方法
首先定义一个注解,如下
import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target; @Target({ElementType.FIELD})
@Retention(RetentionPolicy.RUNTIME)
public @interface ParamNotNull {
}
简单解释一下,interface前面加@的意思是:
@interface 不是interface,是注解类
是jdk1.5之后加入的,java没有给它新的关键字,所以就用@interface 这么个东西表示了
这个注解类,就是定义一个可用的注解,包括这个注解用于什么地方,是类,还是方法,还是property,还是方法入参等等,还有这个注解是否编译后进入class
比如我们知道的用于javadoc的注解,是不进入class文件的。然后在后面你就可以用这个注解写代码了。
总的来说,这就是一个生成javadoc时用到的注释类
/**
* 对非空参数进行校验,使用注解
* @param model javabean 对象
* @throws ClassNotFoundException
*/
public static CheckResult parameterIsNotNull(Object model) {
try {
Field[] fields = model.getClass().getDeclaredFields();
boolean flag = true;
String fieldstr = "字段:";
for (Field field : fields) {
ParamNotNull annotation = field.getAnnotation(ParamNotNull.class);
if(annotation != null){
String name = field.getName();
if(!chechFiled(model,name,field)){
flag = false;
fieldstr = fieldstr + name + " ";
}
}
}
if(flag){//校验通过
return new CheckResult(true);
}else {//有参数校验不通过
return new CheckResult(ApiResponse.error(Syscode.PARAMETER_ERROR,fieldstr+"不能为空!"));
}
}catch (Exception e){
LOG.error(CheckParameter.class,"对非空参数进行校验时异常 e: " + e.getMessage());
return new CheckResult(ApiResponse.error(Syscode.SYSTEM_EXCEPTION));
}
}
private static boolean chechFiled(Object model,String name,Field field) throws Exception{
boolean flag = true;
name = name.substring(0,1).toUpperCase()+name.substring(1); //将属性的首字符大写,方便构造get,set方法
String type = field.getGenericType().toString(); //获取属性的类型
if(type.equals("class java.lang.String")){ //如果type是类类型,则前面包含"class ",后面跟类名
Method m = model.getClass().getMethod("get"+name);
String value = (String) m.invoke(model); //调用getter方法获取属性值
if(StringUtils.isBlank(value)){
flag = false;
}
}else {
Method m = model.getClass().getMethod("get"+name);
Object value = m.invoke(model);
if(value == null){
flag = false;
}
}
return flag;
}
或者只使用反射机制
/**
* 对非空参数进行校验
* @param model javabean 对象
* @param unCheckField 不校验的字段
* @return
*/
public static CheckResult parameterIsNotNull(Object model, Set<String> unCheckField){
try {
boolean flag = true;
String fieldstr = "字段:";
Field[] field = model.getClass().getDeclaredFields(); //获取实体类的所有属性,返回Field数组
for(int j=0 ; j<field.length ; j++){ //遍历所有属性
String name = field[j].getName(); //获取属性的名字
if(unCheckField.contains(name)){
continue;//不需要校验此字段
}
if(!chechFiled(model,name,field[j])){
flag = false;
fieldstr = fieldstr + name + " ";
}
}
if(flag){//校验通过
return new CheckResult(true);
}else {//有参数校验不通过
return new CheckResult(ApiResponse.error(Syscode.PARAMETER_ERROR,fieldstr+"不能为空!"));
}
}catch (Exception e){
LOG.error(CheckParameter.class,"对非空参数进行校验时异常 e: " + e.getMessage());
return new CheckResult(ApiResponse.error(Syscode.SYSTEM_EXCEPTION));
}
}
import java.lang.reflect.Method;
import java.util.ArrayList;
import java.util.List;
import org.apache.commons.lang.StringUtils;
import com.yucheng.cmis.channel.stagedaccess.domain.MapsStagedMaintainInfo;
/**
* 校验参数是否为空
* @author xr
* @param model:参数所在的实体类 paramList:要校验的参数
*
*/
public class ParamCheck {
public static boolean isNotBlank(Object model,List<String> paramList) throws Exception, Exception {
boolean flag = true;
String params = "";
String param = "";
for(int i=0;i<paramList.size();i++) {
params = paramList.get(i);
if (params.indexOf("_") < 0) {
params = params.substring(0,1).toUpperCase()+params.substring(1); //将属性的首字符大写,方便构造get,set方法
System.out.println(params);
Method m = model.getClass().getMethod("get"+params);
String value = (String) m.invoke(model); //调用getter方法获取属性值
if(StringUtils.isBlank(value)){
flag = false;
return flag;
}
} else {
String[] strs = params.split("_");
for (int j=0;j<strs.length;j++) {
params = strs[j].substring(0,1).toUpperCase()+strs[j].substring(1); //将属性的首字符大写,方便构造get,set方法
param += params;
System.out.println(param);
}
Method m = model.getClass().getMethod("get"+param);
String value = (String) m.invoke(model); //调用getter方法获取属性值
if(StringUtils.isBlank(value)){
flag = false;
return flag;
}
}
}
return flag;
}
public static void main(String[] args) throws Exception {
//维护人员信息
MapsStagedMaintainInfo mainInfo = new MapsStagedMaintainInfo();
//mainInfo.setHead("aa");
mainInfo.setBusiManagerStore("bbb");
List<String> paramList = new ArrayList<String>();
paramList.add("head");
paramList.add("busi_manager_store");
boolean result = ParamCheck.isNotBlank(mainInfo, paramList);
System.out.println(result);
}
对前台传过来的实体是否为空 进行为空校验的N种方法的更多相关文章
- 使用java传参调用exe并且获取程序进度和返回结果的一种方法
文章版权由作者李晓晖和博客园共有,若转载请于明显处标明出处:http://www.cnblogs.com/naaoveGIS/ 1.背景 在某个项目中需要考虑使用java后台调用由C#编写的切图程序( ...
- ASP.NET后台中调用前台Javascript函数的几种方法
做web开发,用的技术是aspx.net,可是由于比较习惯于ASP现在做起来,觉得非常别扭,原因在于有很多功能其实在前台可以处理的,但是因为用到了很多webcontrol,导致不断postback.如 ...
- java前台传参json,后台用map或者实体对象接收
(一)前台传js对象,里面包含数组,后台用map接收 (1)第一种情况:数组里不包含js对象 var param ={}: param.id=id; param.name=name; var scor ...
- page = new String(request.getQueryString().getBytes("ISO-8859-1"),"GBK");解决前台传后台乱码问题
page = new String(request.getQueryString().getBytes("ISO-8859-1"),"GBK");解决前台传后台 ...
- RPC 编程 使用 RPC 编程是在客户机和服务器实体之间进行可靠通信的最强大、最高效的方法之一。它为在分布式计算环境中运行的几乎所有应用程序提供基础。
RPC 编程 使用 RPC 编程是在客户机和服务器实体之间进行可靠通信的最强大.最高效的方法之一.它为在分布式计算环境中运行的几乎所有应用程序提供基础.本文介绍 RPC 客户机和服务器之间基本的事件流 ...
- 服务器文档下载zip格式 SQL Server SQL分页查询 C#过滤html标签 EF 延时加载与死锁 在JS方法中返回多个值的三种方法(转载) IEnumerable,ICollection,IList接口问题 不吹不擂,你想要的Python面试都在这里了【315+道题】 基于mvc三层架构和ajax技术实现最简单的文件上传 事件管理
服务器文档下载zip格式 刚好这次项目中遇到了这个东西,就来弄一下,挺简单的,但是前台调用的时候弄错了,浪费了大半天的时间,本人也是菜鸟一枚.开始吧.(MVC的) @using Rattan.Co ...
- 两种方法上传本地文件到github
https://www.jianshu.com/p/c70ca3a02087 自从使用github以来,一直都是在github网站在线上传文件到仓库中,但是有时因为网络或者电脑的原因上传失败.最重要的 ...
- 两种方法上传本地文件到github(转)
自从使用github以来,一直都是在github网站在线上传文件到仓库中,但是有时因为网络或者电脑的原因上传失败.最重要的原因是我习惯本地编辑,完成以后再一起上传github.看过了几个教程,总结出最 ...
- python自动化之上传文件的3种方法和图片预览
ajax上传文件的三种方法 第一种xhr提交 function xhrSubmit(){ // $('#fafafa')[0] var file_obj = document.getElementBy ...
随机推荐
- python requests接口测试
Python 标准库中的 urllib2 模块提供了你所需要的大多数 HTTP 功能,但是它的 API 太渣了.它是为另一个时代.另一个互联网所创建的.它需要巨量的工作,甚至包括各种方法覆盖,来完成最 ...
- SQL Server char,varchar,nchar,nvarchar区别
SQL Server char,varchar,nchar,nvarchar区别 (1) 定义: char: 固定长度,存储ANSI字符,不足的补英文半角空格. nchar: 固 ...
- Vue小案例 之 商品管理------批量删除与商品数量的调整
通过索引进行删除,进行测试,是否获取其索引: 测试效果: 测试代码,在vue中定义一个空的数组,以便后面进行数据的绑定: data:{ imgUrl:'../res/images/', imgName ...
- spring boot 结合Redis 实现工具类
自己整理了 spring boot 结合 Redis 的工具类引入依赖 <dependency> <groupId>org.springframework.boot</g ...
- docker 实践
https://doc.yonyoucloud.com/doc/docker_practice/etcd/etcdctl.html 启动http restful API docker批量映射端口 怎么 ...
- shell实现自动部署两台tomcat项目+备份
就做个记录吧, 其实也没啥好说的. 主机 #!/bin/bash TODAY=$(date -d 'today' +%Y-%m-%d-%S) MIP="192.168.180.24" ...
- wireshark抓包的过滤规则
使用wireshark抓包的过滤规则.1.过滤源ip.目的ip.在wireshark的过滤规则框Filter中输入过滤条件.如查找目的地址为192.168.101.8的包,ip.dst==192.16 ...
- Flask学习【第1篇】:Flask介绍
Flask介绍(轻量级的框架,非常快速的就能把程序搭建起来) Flask是一个基于Python开发并且依赖jinja2模板和Werkzeug WSGI服务的一个微型框架,对于Werkzeug本质是So ...
- 闪存中的NorFlash、NandFlash及eMMC三者的区别【转】
本文转载自:https://blog.csdn.net/Blazar/article/details/77843655 快闪存储器(英语:Flash Memory),是一种电子式可清除程序化只读存储器 ...
- #2718. 「NOI2018」归程 kruskal重构树
链接 https://loj.ac/problem/2718 思路 我们希望x所在的连通块尽量的大,而且尽量走高处 离线的话可以询问排序,kruskal过程中更新答案 在线就要用kruskal重构树 ...