首先定义一个注解,如下

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种方法的更多相关文章

  1. 使用java传参调用exe并且获取程序进度和返回结果的一种方法

    文章版权由作者李晓晖和博客园共有,若转载请于明显处标明出处:http://www.cnblogs.com/naaoveGIS/ 1.背景 在某个项目中需要考虑使用java后台调用由C#编写的切图程序( ...

  2. ASP.NET后台中调用前台Javascript函数的几种方法

    做web开发,用的技术是aspx.net,可是由于比较习惯于ASP现在做起来,觉得非常别扭,原因在于有很多功能其实在前台可以处理的,但是因为用到了很多webcontrol,导致不断postback.如 ...

  3. java前台传参json,后台用map或者实体对象接收

    (一)前台传js对象,里面包含数组,后台用map接收 (1)第一种情况:数组里不包含js对象 var param ={}: param.id=id; param.name=name; var scor ...

  4. page = new String(request.getQueryString().getBytes("ISO-8859-1"),"GBK");解决前台传后台乱码问题

    page = new String(request.getQueryString().getBytes("ISO-8859-1"),"GBK");解决前台传后台 ...

  5. RPC 编程 使用 RPC 编程是在客户机和服务器实体之间进行可靠通信的最强大、最高效的方法之一。它为在分布式计算环境中运行的几乎所有应用程序提供基础。

    RPC 编程 使用 RPC 编程是在客户机和服务器实体之间进行可靠通信的最强大.最高效的方法之一.它为在分布式计算环境中运行的几乎所有应用程序提供基础.本文介绍 RPC 客户机和服务器之间基本的事件流 ...

  6. 服务器文档下载zip格式 SQL Server SQL分页查询 C#过滤html标签 EF 延时加载与死锁 在JS方法中返回多个值的三种方法(转载) IEnumerable,ICollection,IList接口问题 不吹不擂,你想要的Python面试都在这里了【315+道题】 基于mvc三层架构和ajax技术实现最简单的文件上传 事件管理

    服务器文档下载zip格式   刚好这次项目中遇到了这个东西,就来弄一下,挺简单的,但是前台调用的时候弄错了,浪费了大半天的时间,本人也是菜鸟一枚.开始吧.(MVC的) @using Rattan.Co ...

  7. 两种方法上传本地文件到github

    https://www.jianshu.com/p/c70ca3a02087 自从使用github以来,一直都是在github网站在线上传文件到仓库中,但是有时因为网络或者电脑的原因上传失败.最重要的 ...

  8. 两种方法上传本地文件到github(转)

    自从使用github以来,一直都是在github网站在线上传文件到仓库中,但是有时因为网络或者电脑的原因上传失败.最重要的原因是我习惯本地编辑,完成以后再一起上传github.看过了几个教程,总结出最 ...

  9. python自动化之上传文件的3种方法和图片预览

    ajax上传文件的三种方法 第一种xhr提交 function xhrSubmit(){ // $('#fafafa')[0] var file_obj = document.getElementBy ...

随机推荐

  1. webform 使用富文本编辑器

    <div class="form-group"> <label class="col-xs-2 control-label text-right&quo ...

  2. MMU工作原理(转)

    源: MMU工作原理

  3. matplotlib 画动态图以及plt.ion()和plt.ioff()的使用

    学习python的道路是漫长的,今天又遇到一个问题,所以想写下来自己的理解方便以后查看. 在使用matplotlib的过程中,常常会需要画很多图,但是好像并不能同时展示许多图.这是因为python可视 ...

  4. P2147 [SDOI2008]洞穴勘测(LCT)

    P2147 [SDOI2008]洞穴勘测 裸的LCT. #include<iostream> #include<cstdio> #include<cstring> ...

  5. 11: python中的轻量级定时任务调度库:schedule

    1.1 schedule 基本使用 1.schedule 介绍 1. 提到定时任务调度的时候,相信很多人会想到芹菜celery,要么就写个脚本塞到crontab中. 2. 不过,一个小的定时脚本,要用 ...

  6. Java快捷键与搜狗输入法快键的冲突

    搜狗五笔,简繁体转换快捷键 ctrl+shift+F Java编辑器 格式化 Ctrl+Shift+F 搜狗输入法 搜狗词典 Ctrl+/ Java编辑器 取消注释 Ctrl+/ Java编辑器 注释 ...

  7. 20165211 2017-2018-2 《Java程序设计》课程总结

    20165211 2017-2018-2 <Java程序设计>课程总结 一.每周作业及实验报告博客链接汇总 预备作业1:我期望的师生关系 预备作业2:学习基础和C语言调查 预备作业3:Li ...

  8. 20145325张梓靖 《网络对抗技术》 MSF基础应用

    20145325张梓靖 <网络对抗技术> MSF基础应用 实验内容 掌握metasploit的基本应用方式以及常用的三种攻击方式的思路 主动攻击,即对系统的攻击,不需要被攻击方配合,这里以 ...

  9. topcoder srm 686 div1

    problem1 link 左括号和右括号较少的一种不会大于20.假设左括号少.设$f[i][mask][k]$表示处理了前$i$个字符,其中留下的字符以$k$开头($k=0$表示'(',$k=1$表 ...

  10. linux基础之网络基础配置

    基础命令:ifconfig/route/netstat,ip/ss,nmcli 一.ifconfig/route/netstat相关命令 1.  ifconfig - configure a netw ...