参数如何校验?撸主很久之前的项目都是在前端页面一个个 if else
的,后来就用了一系列的前端校验框架,比如 layui
iview
等等,几个样式属性就可以轻松搞定,的确是美滋滋。
后端验证
那么问题来了?前端已经验证了,后端还有必要再校验吗?
如果非要有个结果,答案只能是不安全的,虽然客户端自己对自己已经做了验证,但是不能避免一些恶意用户人为的修改表单直接发送欺骗请求。
所以说,从安全的角度来说,单纯的依靠前端验证,是不安全的,任何健壮的系统都必须在后端进行验证。
当然,你也不必担心后台再写一坨if else
,这里推荐大家一款参数校验神器 Hibernate-Validator
。SpringBoot
的标配JPA
是自带的,小伙伴们直接使用即可。
注解
基本提供了常用的校验注解,如果不满足业务,可以通过@Pattern
自行定义正则表达式。
@Null 被注释的元素必须为null
@NotNull 被注释的元素不能为null
@AssertTrue 被注释的元素必须为true
@AssertFalse 被注释的元素必须为false
@Min(value) 被注释的元素必须是一个数字,其值必须大于等于指定的最小值
@Max(value) 被注释的元素必须是一个数字,其值必须小于等于指定的最大值
@DecimalMin(value) 被注释的元素必须是一个数字,其值必须大于等于指定的最小值
@DecimalMax(value) 被注释的元素必须是一个数字,其值必须小于等于指定的最大值
@Size(max,min) 被注释的元素的大小必须在指定的范围内。
@Digits(integer,fraction) 被注释的元素必须是一个数字,其值必须在可接受的范围内
@Past 被注释的元素必须是一个过去的日期
@Future 被注释的元素必须是一个将来的日期
@Pattern(value) 被注释的元素必须符合指定的正则表达式。
@Email 被注释的元素必须是电子邮件地址
@Length 被注释的字符串的大小必须在指定的范围内
@NotEmpty 被注释的字符串必须非空
@Range 被注释的元素必须在合适的范围内
案例
这里以用户注册为例:
@Data
@Entity
@Table(name = “sys_user”)
public class SysUser implements Serializable{
/**
- 用户id
*/
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name = “user_id”, nullable = false, length = 20)
private Long userId;
/**
- 用户名
*/
@NotNull
@Column(name = “username”, nullable = false, length = 50)
private String username;
/**
- 密码
*/
@Size(min = 6, max = 25, message = “密码长度要求6到25之间”)
@Column(name = “password”, nullable = false, length = 50)
private String password;
/**
- 姓名(昵称)
*/
@NotNull
@Column(name = “nickname”, length = 50)
private String nickname;
/**
- 邮箱
*/
@Email(message=“邮箱格式不正确”)
@Column(name = “email”, length = 100)
private String email;
/**
- 手机号
/
@Pattern(regexp=“^((13[0-9])|(14[5|7])|(15([0-3]|[5-9]))|(17[013678])|(18[0,5-9]))\d{8}$”,message=“手机格式不正确”)
@Column(name = “mobile”, length = 100)
private String mobile;
/*
最后
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助。
因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点!不论你是刚入门Android开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门!
如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
😕/bbs.csdn.net/topics/618191877)
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!