SpringMVC之完成对前端传来的数据进行校验

假设您需要在网页上注册一个账号,其中有一项需要填入您的年龄,如果您不小心填了一个字符串,那么您的这个账号是不可能成功进行注册的,而本篇文章实现的功能就是,在后端将前端串传入的数据进行校验和识别。

第一步:在pom.xml导入依赖

         <dependency>
            <groupId>org.hibernate.validator</groupId>
            <artifactId>hibernate-validator</artifactId>
            <version>6.1.0.Final</version>
        </dependency>
        <dependency>
            <groupId>jakarta.validation</groupId>
            <artifactId>jakarta.validation-api</artifactId>
            <version>2.0.2</version>
        </dependency>

第二步:配置框架配置文件web.xml中,将这个功能加载到SpringMVC框架中

    <bean class="org.springframework.validation.beanvalidation.LocalValidatorFactoryBean" id="validatorFactoryBean">
        <property name="providerClass" value="org.hibernate.validator.HibernateValidator"></property>
    </bean>
 <mvc:annotation-driven validator="validatorFactoryBean"/>

第三步:配置校验数据条件(通过SpringMVC的框架注解来实现限制)

        注意:注解有很多种,这里只介绍几种经常使用的

package demo1;

import org.springframework.lang.NonNull;

import javax.validation.constraints.*;

public class yan {
    @NotNull(message = "id数据为空")
    private Integer id;
    @NotNull(message = "id数据为空")
    @Size(min =2 ,max = 10)
    private String name;
    @Email()
    private String email;
    @NotNull(message = "age数据输入错误")
    @Max(150)
    @Min(0)
    private Integer age;

    @Override
    public String toString() {
        return "CT_yanzheng{" +
                "id=" + id +
                ", name='" + name + '\'' +
                ", email='" + email + '\'' +
                ", age=" + age +
                '}';
    }

    @NonNull
    public Integer getId() {
        return id;
    }

    public void setId(@NonNull Integer id) {
        this.id = id;
    }

    @NonNull
    public String getName() {
        return name;
    }

    public void setName(@NonNull String name) {
        this.name = name;
    }

    public String getEmail() {
        return email;
    }

    public void setEmail(String email) {
        this.email = email;
    }

    @NonNull
    public Integer getAge() {
        return age;
    }

    public void setAge(@NonNull Integer age) {
        this.age = age;
    }
}
  • @NotNull 表示这个字段不能为空
  • @Size 中描述了这个字符串长度的限制
  • @Email 表示这个字段的值必须是一个邮箱地址
  • @Max 表示这个字段的最大值

其他注解:

 第四步:创建框架的控制器

package demo1;


import org.springframework.stereotype.Controller;
import org.springframework.validation.BindingResult;
import org.springframework.validation.ObjectError;
import org.springframework.validation.annotation.Validated;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;

import java.util.Arrays;
import java.util.List;

@Controller
public class con1 {
    @RequestMapping(value = "/yan",produces = "text/html;charset=utf-8")
    @ResponseBody
    public String play(@Validated yan ct_yanzheng, BindingResult bindingResult){
    //@Validated注解标注着定义的那些限制条件,得以实现
//BindingResult 通过这个类来判断前端传来的数据是否有错误
        System.out.println("yan" +ct_yanzheng);
        String[] play1 = new String[4];
        if(bindingResult!=null) {
            List<ObjectError> allErrors = bindingResult.getAllErrors();   //将错误信息遍历出来

            int m = 0;
            for (ObjectError objectError : allErrors) {
                String last = objectError.getObjectName() + ":" + objectError.getDefaultMessage();
                System.out.println(last);
                play1[m] = last;
                m++;
            }
            return Arrays.toString(play1);}     //如果出现错误,将错误标记信息传到前端
        else return "输入成功";
        }
}

创建前端界面:

<%--
  Created by IntelliJ IDEA.
  User: lenovo
  Date: 2022/11/17
  Time: 21:37
  To change this template use File | Settings | File Templates.
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>Title</title>
</head>
<body>
<form action="/yan" method="post">
    <table>
        <tr>
            <td>学生编号:</td>
            <td><input type="text" name="id"></td>
        </tr>
        <tr>
            <td>学生姓名:</td>
            <td><input type="text" name="name"></td>
        </tr>
        <tr>
            <td>学生邮箱:</td>
            <td><input type="text" name="email"></td>
        </tr>
        <tr>
            <td>学生年龄:</td>
            <td><input type="text" name="age"></td>
        </tr>
        <tr>
            <td colspan="2">
                <input type="submit" value="提交">
            </td>
        </tr>
    </table>
</form>
</body>
</html>

 项目执行:

 

结果输出:

将错误信息遍历在前端网页上 

 

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

不想睡醒的梦

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值