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

news2025/1/17 18:03:16

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

第一步:在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>

 项目执行:

 

结果输出:

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

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/23813.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

yolo数据集的制作教程之海绵宝宝数据集的制作

yolo海绵宝宝数据集的制作 1、视频转图片 新建名为hm的文件目录&#xff0c;用于存放图片 代码如下&#xff1a; import cv2 from datetime import datetime def video_to_frames(path,savepath,m):video_cap cv2.VideoCapture()video_cap.open(path)fps video_cap.get(…

【云原生系列】第三讲:Knative 之 Serving

目录 序言 1. knative 1.1 发展历程 1.2 特点 2.Serving 2.1 基本介绍 2.2 支持类型 2.3 资源类型 2.3.1 service 2.3.2 Route 2.3.3 Configuration 2.3.4 Revision 2.4 Serving管理能力实现方式 2.4.1 四个 kubernetes Service 2.4.2 二个Deployment 2.4.3…

5G无线技术基础自学系列 | 5G下行物理信道和信号

素材来源&#xff1a;《5G无线网络规划与优化》 一边学习一边整理内容&#xff0c;并与大家分享&#xff0c;侵权即删&#xff0c;谢谢支持&#xff01; 附上汇总贴&#xff1a;5G无线技术基础自学系列 | 汇总_COCOgsta的博客-CSDN博客 5G空中接口下行的物理信道包括PB CH、P…

[附源码]计算机毕业设计JAVA基于web旅游网站的设计与实现

[附源码]计算机毕业设计JAVA基于web旅游网站的设计与实现 项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; …

docker打包多架构镜像(manifest)

在docker仓库上&#xff0c;经常能看到这样的镜像 在一个”镜像“中&#xff0c;包含了三个架构的镜像 本质上&#xff0c;外部看到的这个镜像&#xff0c;其实不算是一个镜像&#xff0c;应该称它为镜像清单列表&#xff08;manifest list&#xff09; manifest是一个文件&a…

通过面积证明:两个函数相乘 / 相除的导数为什么长成这样?

参考视频 MIT 微积分课程 两个函数相乘的导数 (f(x)g(x))′f′(x)g(x)g′(x)f(x)(f(x)g(x))^{}f^{}(x)g(x)g^{}(x)f(x)(f(x)g(x))′f′(x)g(x)g′(x)f(x) 这是我们都非常熟悉的公式&#xff0c;熟悉到根本不知道是咋推出来的其实推导这个公式有两种方法&#xff0c;一种就是靠…

微服务平滑迁移上云最佳实践

作者&#xff1a;草谷 背景 许多企业在做微服务架构改造的时候&#xff0c;在自建还是上云的选择上难以决策&#xff0c;选择上云后&#xff0c;在微服务上云过程中&#xff0c;如何能够做到不影响业务情况下平滑迁移呢&#xff0c;通过阅读本文&#xff0c;你可以快速获得以…

树之基本概念(有图头真相)

文章目录树的概念及结构1.树的概念2.树的相关概念3.树的表示4.树在实际中的应用树的概念及结构 1.树的概念 树是一种非线性的数据结构&#xff0c;它是由n&#xff08;n>0&#xff09;个有限结点组成一个具有层次关系的集合。把它叫做树是因为它看起来像一棵倒挂的树&#…

高项 干系人管理论文

4个过程&#xff1a; 1&#xff0c;识别干系人&#xff1a;识别能影响项目决策、活动或结果的个人、群体或组织&#xff0c;以及被项目、活动或者结果影响的个人、群体或者组织&#xff0c;并分析和记录他们的相关信息的过程。这些信息包括他们的利益、参与度、互相依赖、影响…

PDF怎么编辑文字?教你两招非常实用的方法

怎么在PDF文件上直接编辑文字呢&#xff1f;相信这是大家在刚接触PDF文件不久时发出的疑问。在发现文件中有需要改正的地方&#xff0c;想要编辑时发现编辑不了&#xff0c;出现这种情况时应该怎么办呢&#xff1f;今天教大家两种非常简单实用的方法&#xff0c;有需要的小伙伴…

《元宇宙工程》南京首发 落地实用是关键

2022年11月20日上午&#xff0c;由江苏省人工智能学会、南京信息工程大学人工智能学院&#xff08;未来技术学院&#xff09;、中国移动通信联合会元宇宙产业工作委员会联合主办&#xff0c;由南京信息工程大学元宇宙研究院、江苏省人工智能学会元宇宙专委会&#xff08;筹&…

PMP考前最后2天思路整理

1 问题解决的思路&#xff0c;先分析&#xff0c;再行动。要直接、要直面。要有担当&#xff0c;要有作为&#xff0c;敢负责任。 2 风险管理里面的三个文件一定要分清楚&#xff1a;风险管理计划、风险登记册和风险报告。风险应对的五种方法每个是什么。各自在书里面举的例子…

NAND闪存改变了现代生活

1989年 我出生了&#xff0c; 额&#xff0c;扯远了。 1989年NAND闪存面世了&#xff0c;它曾经且正在改变了我们的日常生活。 NAND 闪存发明之所以伟大&#xff0c;是因为&#xff0c;有了这项颠覆性的发明&#xff0c;才有了我们现如今用的智能手机的高速大容量内存(eMMC、UF…

react-window构造的虚拟列表使用react-resizable动态调整宽度和使用react-drag-listview拖拽变换列位置的问题

文章目录react-window构造的虚拟列表使用react-resizable动态调整宽度和使用react-drag-listview拖拽变换列位置的问题需求问题问题根源部分代码参考react-window构造的虚拟列表使用react-resizable动态调整宽度和使用react-drag-listview拖拽变换列位置的问题 需求 项目中使…

java项目-第154期ssm足球赛会管理系统-ssm毕业设计_计算机毕业设计

java项目-第154期ssm足球赛会管理系统-ssm毕业设计_计算机毕业设计 【源码请到资源专栏下载】 今天分享的项目是《ssm足球赛会管理系统》 该项目分为2个角色&#xff0c;管理员、用户。 用户可以浏览前台,包含功能有&#xff1a; 首页、球队介绍、球星介绍、线下足球、赛论坛信…

Revit中项目的正负零零,尺寸标注,标注生成问题

一、 Revit中如何改变项目的正负零零 有时候&#xff0c;在一个项目中&#xff0c;我们要改变项目的 正负零零&#xff0c;如下图 第一步&#xff0c;打开视图的“可见性/图形”&#xff0c;如图2 第二步&#xff0c;在“可见性/图形替换”中勾选“项目基点”&#xff0c;如图 …

TK爆品剖析 水晶首饰降临节日历持续火爆TikTok,独立站卖到断货

圣诞节是年末促销旺季的关键节点&#xff0c;很多商家都会推出圣诞主题礼物产品&#xff0c;比如圣诞树、圣诞贺卡、圣诞老人等等&#xff0c;但很少会推出降临节日历。 其实&#xff0c;“降临节日历”一直是人们在圣诞节前最喜欢的礼物。谷歌趋势显示&#xff0c;2021年圣诞节…

[Spring Cloud] Ribbon介绍与定义负载均衡

✨✨个人主页:沫洺的主页 &#x1f4da;&#x1f4da;系列专栏: &#x1f4d6; JavaWeb专栏&#x1f4d6; JavaSE专栏 &#x1f4d6; Java基础专栏&#x1f4d6;vue3专栏 &#x1f4d6;MyBatis专栏&#x1f4d6;Spring专栏&#x1f4d6;SpringMVC专栏&#x1f4d6;SpringBoot专…

QXlsx 使用

QXls使用分两种方式&#xff1a; 1 直接加载pri文件&#xff0c;就可以使用&#xff1b;2 编译后作为Qt的模块加载使用&#xff1b; 此文章主要针对第二种使用方式做记录&#xff0c;该方式又分为两种编译器进行说明&#xff1a; 第一种&#xff0c;使用MinGW64位编译器&…

nginx部署web项目(跟着搞不出来,来砍我)

前端打包成dist&#xff0c;详情可以参考我的vue博客 vue速学_我要用代码向我喜欢的女孩表白的博客-CSDN博客 nginx下载地址:nginx1.16.1离线安装包_nginx1.16.1依赖-Web服务器文档类资源-CSDN下载 &#xff08;如果报错缺少依赖&#xff0c;可以参考我的nginx-rtmp直播流博客…