Spring之JSR303与拦截器

本文介绍了Spring MVC中JSR303服务端验证的实现,包括实体类注解、控制层解析以及前端测试。接着详细探讨了拦截器的概念、与过滤器的区别,并给出了应用场景,如日志记录、权限检查等。讲解了拦截器的三个关键方法:preHandle、postHandle和afterCompletion。最后,通过拦截器实现了登录权限控制的示例。
摘要由CSDN通过智能技术生成

目录

一,JSR303

二,拦截器

什么是拦截器

拦截器与过滤器

 应用场景   

 拦截器链

登录权限控制


一,JSR303

服务端验证

1.导入pom依赖

 <dependency>
      <groupId>org.hibernate</groupId>
      <artifactId>hibernate-validator</artifactId>
      <version>6.0.7.Final</version>
    </dependency>

2.后端

在实体类中加上注解

解析:
  @NotNull :作用于基本数据类型
  @NotEmpty    作用于集合
  @NotBlank    作用于字符串
 

package com.dengxiyan.ssm.model;

import javax.validation.constraints.NotBlank;
import javax.validation.constraints.NotEmpty;
import javax.validation.constraints.NotNull;
import javax.validation.constraints.Size;



public class Clazz {
    @NotNull(message = "cid不能为空")
    protected Integer cid;

    @NotBlank(message = "班级名称不能为空")
    protected String cname;

    @NotBlank(message = "教员名称不能为空")
    protected String cteacher;

    protected String pic;

    public Clazz(Integer cid, String cname, String cteacher, String pic) {
        this.cid = cid;
        this.cname = cname;
        this.cteacher = cteacher;
        this.pic = pic;
    }

    public Clazz() {
        super();
    }

    public Integer getCid() {
        return cid;
    }

    public void setCid(Integer cid) {
        this.cid = cid;
    }

    public String getCname() {
        return cname;
    }

    public void setCname(String cname) {
        this.cname = cname;
    }

    public String getCteacher() {
        return cteacher;
    }

    public void setCteacher(String cteacher) {
        this.cteacher = cteacher;
    }

    public String getPic() {
        return pic;
    }

    public void setPic(String pic) {
        this.pic = pic;
    }
}

 控制层

解析:
     @valid 是与实体类中的服务端校验,注解配合使用的
      bindingresult 存放校验的错误信息
     @param clazz
     @param bindingResult
     @return
   

//给数据添加服务端效验
    @RequestMapping("/valiadd")
    public String valiadd(@Valid Clazz clazz, BindingResult bindingResult,HttpServletRequest request){
        if(bindingResult.hasErrors()){
            Map msg = new HashMap();
            //违背规则
            List<FieldError> fieldErrors = bindingResult.getFieldErrors();
            for (FieldError fieldError : fieldErrors) {
                //cid 不能为空
                System.out.println(fieldError.getField() + ":" + fieldError.getDefaultMessage());
//                msg.put(cid,cid不能为空);
                msg.put(fieldError.getField(),fieldError.getDefaultMessage());
            }
           request.setAttribute("msg",msg);
            //如果出现了错误,应该将提示语显示在表单提交元素后方
            return "clzEdit";
        }else{

            this.clazzBiz.insertSelective(clazz);
        }
        return "redirect:/clz/list";

    }
package com.dengxiyan.ssm.controller;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;

/**
 * @author dxy
 * @site www.javadxy.com
 * @company ds公司
 * @create  2022-08-19 18:15
 */
@Controller
public class HelloController {

    @RequestM
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值