Jfinal的初了解(三)

在进行后端开发的过程当中,都会需要使用到字段非空判断,请求的字段如果为空的话,则不走Controller。

本文记录一下在JFinal当中配置自定义注解非空判断。

首先 新建一个注解类
import java.lang.annotation.Inherited;
import java.lang.annotation.Retention;
import java.lang.annotation.Target;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.ElementType;

@Inherited
@Retention(RetentionPolicy.RUNTIME)
@Target({ElementType.TYPE, ElementType.METHOD})
public @interface EmptyInterface {
    String[] value();
}

创建自定义的Handler 继承自JFinal的Handler
/**
 * Created by Pencilso on 2017/5/4.
 */
public class HandlerInter extends Handler {
    @Override
    public void handle(String target, HttpServletRequest request, HttpServletResponse response, boolean[] isHandled) {
        String urlPara[] = {null};
        Action action = JFinal.me().getAction(target, urlPara);
        EmptyInterface annotation = action.getMethod().getAnnotation(EmptyInterface.class);
        if (annotation != null) {
            noEmpty(annotation, target, request, response, isHandled);
        } else next.handle(target, request, response, isHandled);
    }

    public void noEmpty(EmptyInterface annotation, String target, HttpServletRequest request, HttpServletResponse response, boolean[] isHandled) {
        String header = request.getHeader("Content-Type"); //取出head头
        if (header != null && header.indexOf("multipart/form-data") != -1) { //判断是否是form-data 否则有可能会报错  之前线上出现过一次log信息
            request = new MultipartRequest(request);
            ((MultipartRequest) request).getFiles();
        }
        String[] value = annotation.value();
        for (String v : value) {
            String parameter = request.getParameter(v);
            if (parameter == null || parameter.trim().length() == 0) {
                Utils.outEmpty(response, request, v);
                isHandled[0] = true;
                break;
            }
        }
        if (!isHandled[0])
            next.handle(target, request, response, isHandled);
    }
}

新建一个Utils类
 /**
 *
 * @param response 响应
 * @param request   请求
 * @param param 为空的字段
 */
public static void outEmpty(HttpServletResponse response, HttpServletRequest request, String param) {
    try {
        response.setHeader("Content-Type", "application/json;charset=UTF-8"); //设置返回头是json格式
        PrintWriter writer = response.getWriter();
        request.getInputStream().close();
        writer.println(ErrorInfo.Json(CodeUtils.ONERROR, param + " can 'not null").toString());  //输出错误信息,我这里将其封装了起来 封装了一个JSON的数据
        writer.flush();
        writer.close();
    } catch (Exception e) {
    }
}
打开JFinal的Config类,在configHandler(Handlers me) 方法下 将自定义的Handler拦截器加入。
使用方法
Jfinal的初了解(三)_第1张图片
单参使用可以直接 @EmptyInterface("field") 多参需要大括号扩起来。
为空测试
Jfinal的初了解(三)_第2张图片
正常测试
Jfinal的初了解(三)_第3张图片

起初本想通过拦截全局Controller来进行字段非空验证,后来发现 一个Clear就将其给清除掉了。虽然Clear可以指定清除某一个拦截器,但不是很方便。

虽然官方也有Validator 配置,不过感觉不好使。

你可能感兴趣的:(Jfinal的初了解(三))