Java web小记

1、Java Web设置页面刷新的方法(两种):

    response.setHeader("refresh", "0.3," + request.getHeader("Referer"));
    response.getWriter().print("<meta http-equiv='Refresh' content='5;url=http://www.baidu.com.cn' />");

 

2、后端数据校验(JSR303/JSR-349、javax validation、hibernate validation、spring validation)

后端数据校验如:请求参数不能为null、数值至少为5、email参数符合邮箱地址规则等,通常涉及到上述几种工具,其区别:

  • JSR303/JSR-349、javax validation:JSR303是一项标准、JSR-349是其升级版本,添加了一些新特性,他们规定一些校验规范即校验注解,如@Null,@NotNull,@Pattern,他们位于javax.validation.constraints包下,只提供规范不提供实现
  • hibernate validation是对该规范的实践(不要将hibernate和数据库orm框架联系在一起),他提供了相应的实现,并增加了一些其他校验注解,如@Email,@Length,@Range等等,他们位于org.hibernate.validator.constraints包下
  • spring对hibernate validation进行了二次封装以方便使用,其在springmvc模块中添加了自动校验并将校验信息封装进了特定的类中、还支持指定groups以进行分组校验。以此可见,下面说到的分组是Spring validation提供的功能

在使用时最好用规范,这样可以在不改变代码的情况下选用其他具体实现。

 

使用

1、指定约束:在Bean中的字段上加上@NotNull等注解(大多为 javax.validation.constraints 下的注解);

2、启用约束:在Controller请求方法的Bean参数前加上@Validated即可( org.springframework.validation.annotation.Validated ),也可用@Valid( javax.validation.constraints.Valid )。

进阶

  • 嵌套的内部对象的验证:在Person p有个字段List<Car> cars,若在验证p时同时要验证Car的price等字段,可以在cars前加上 @Valid 即可
  • 分组:在Bean中可以指定字段验证所属的groups、在请求参数中可以指定应用哪种groups进行验证,只会触发相应的groups进行验证;若未指定groups则默认属于组javax.validation.groups.Default,更多可参阅(分组)示例:
    //Bean中的定义
        @Min(value = 18, groups = { Adult.class ,Default.class}) // groups限制触发此约束的条件,groups中无元素则默认为Default.class
        private Integer age;
    
    
    //Controller中的验证
        @PostMapping("/foo1")
        public String foo1(@RequestBody @Validated({ Adult.class }) Foo foo1) {
            System.out.println("------- res1 -------");
            return "foo1 done.";
        }
    View Code
  • 分组顺序验证:通过@GroupSequence定义一个组SeqGroup,里面包含若干其他组,则SeqGroup可起顺序验证若干组的作用。示例:
    public interface GroupA {}
     
    public interface GroupB {}
     
    @GroupSequence( { Default.class, GroupA.class, GroupB.class })
    public interface SeqGroup {}
    View Code
  • 可以不用在方法中与每个请求参数都对应一个BindingResult,而是拦截Controller异常进行处理:违背约束时会抛MethodArgumentNotValidException异常。示例:
    @Slf4j
    @ControllerAdvice
    class GlobalControllerExceptionHandler {
    
        @ResponseBody
        @ExceptionHandler(Throwable.class)
        public String handleApiBindException(Throwable e) {
            String msg = e.getLocalizedMessage();
    
            log.error("param validation error", e);
    
            if (e instanceof BindException) {
    //            return handleApiBindException((BindException) e);
            }
            if (e instanceof MethodArgumentNotValidException) {
                BindingResult bindingResult2 = ((MethodArgumentNotValidException) e).getBindingResult();
                if (bindingResult2.hasErrors()) {
                    for (FieldError fieldError : bindingResult2.getFieldErrors()) {
                        System.out.println(String.format("%s %s %s %s", fieldError.getCode(), fieldError.getField(),
                                fieldError.getDefaultMessage(), fieldError.getRejectedValue()));
                    }
    
                }
                msg = ((MethodArgumentNotValidException) e).getBindingResult().getFieldErrors().stream()
                        .map(fe -> String.format("'%s'%s", fe.getField(), fe.getDefaultMessage()))
                        .collect(Collectors.joining(","));
            }
            if (e instanceof ConstraintViolationException) {
    //            return handleApiConstraintViolationException((ConstraintViolationException) e);
            }
    
            return msg;
        }
    }
    View Code

总结:可见用的最多的是spring的 @Validated 、其次是javax的 @Valid ,其多数基本功能相似,但在注解适用位置、分组、嵌套验证支持上有区别。

注解适用位置:前者可用于修饰类型、方法、方法参数上,不能修饰成员变量;后者可用于方法、方法参数、成员变量、构造函数上。能否用于成员属性决定了是否支持嵌套验证。

分组:前者支持,后者不支持。

嵌套验证:前者不支持,后者支持。

 

更多详情参阅:https://www.cnkirito.moe/spring-validation/https://blog.csdn.net/qq_27680317/article/details/79970590

 

转载于:https://www.cnblogs.com/z-sm/p/4872259.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值