电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術(shù)文章
文章詳情頁

Spring mvc服務(wù)端數(shù)據(jù)校驗實現(xiàn)流程詳解

瀏覽:4日期:2023-08-12 15:55:35

B/S 系統(tǒng)中對http 請求數(shù)據(jù)的校驗多數(shù)在客戶端進(jìn)行,這也是出于簡單及用戶體驗性上考慮,但是在一些安全性要求高的系統(tǒng)中服務(wù)端校驗是不可缺少的,實際上,幾乎所有的系統(tǒng),凡是涉及到數(shù)據(jù)校驗,都需要在服務(wù)端進(jìn)行二次校驗。為什么要在服務(wù)端進(jìn)行二次校驗?zāi)兀窟@需要理解客戶端校驗和服務(wù)端校驗各自的目的。

客戶端校驗,我們主要是為了提高用戶體驗,例如用戶輸入一個郵箱地址,要校驗這個郵箱地址是否合法,沒有必要發(fā)送到服務(wù)端進(jìn)行校驗,直接在前端用 js 進(jìn)行校驗即可。但是大家需要明白的是,前端校驗無法代替后端校驗,前端校驗可以有效的提高用戶體驗,但是無法確保數(shù)據(jù)完整性,因為在 B/S 架構(gòu)中,用戶可以方便的拿到請求地址,然后直接發(fā)送請求,傳遞非法參數(shù)。服務(wù)端校驗,雖然用戶體驗不好,但是可以有效的保證數(shù)據(jù)安全與完整性。綜上,實際項目中,兩個一起用。

Spring 支持JSR-303 驗證框架,JSR-303 是 JAVA EE 6 中的一項子規(guī)范,叫做 Bean Validation,官方參考實現(xiàn)是 Hibernate Validator(與Hibernate ORM 沒有關(guān)系),JSR-303 用于對 Java Bean 中的字段的值進(jìn)行驗證。

普通校驗

普通校驗,是這里最基本的用法。

首先,我們需要加入校驗需要的依賴:

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

接下來,在 SpringMVC 的配置文件中配置校驗的 Bean:

<bean id='validatorFactoryBean'> <property name='providerClass' value='org.hibernate.validator.HibernateValidator'/></bean><mvc:annotation-driven validator='validatorFactoryBean'/>

配置時,提供一個 LocalValidatorFactoryBean 的實例,然后 Bean 的校驗使用 HibernateValidator。

這樣,配置就算完成了。

接下來,我們提供一個添加學(xué)生的頁面:

<form action='/addstudent' method='post'> <table> <tr> <td>學(xué)生編號:</td> <td><input type='text' name='id'></td> </tr> <tr> <td>學(xué)生姓名:</td> <td><input type='text' name='name'></td> </tr> <tr> <td>學(xué)生郵箱:</td> <td><input type='text' name='email'></td> </tr> <tr> <td>學(xué)生年齡:</td> <td><input type='text' name='age'></td> </tr> <tr> <td colspan='2'><input type='submit' value='提交'> </td> </tr> </table></form>

在這里需要提交的數(shù)據(jù)中,假設(shè)學(xué)生編號不能為空,學(xué)生姓名長度不能超過 10 且不能為空,郵箱地址要合法,年齡不能超過 150。那么在定義實體類的時候,就可以加入這個判斷條件了。

public class Student { @NotNull private Integer id; @NotNull @Size(min = 2,max = 10) private String name; @Email private String email; @Max(150) private Integer age;...}

在這里:

@NotNull 表示這個字段不能為空 @Size 中描述了這個字符串長度的限制 @Email 表示這個字段的值必須是一個郵箱地址 @Max 表示這個字段的最大值

定義完成后,接下來,在 Controller 中定義接口:

@Controllerpublic class StudentController { @RequestMapping('/addstudent') @ResponseBody public void addStudent(@Validated Student student, BindingResult result) { if (result != null) { //校驗未通過,獲取所有的異常信息并展示出來 List<ObjectError> allErrors = result.getAllErrors(); for (ObjectError allError : allErrors) {System.out.println(allError.getObjectName()+':'+allError.getDefaultMessage()); } } }}

在這里:

@Validated 表示 Student 中定義的校驗規(guī)則將會生效 BindingResult 表示出錯信息,如果這個變量不為空,表示有錯誤,否則校驗通過。

接下來就可以啟動項目了。訪問 jsp 頁面,然后添加 Student,查看校驗規(guī)則是否生效。

默認(rèn)情況下,打印出來的錯誤信息時系統(tǒng)默認(rèn)的錯誤信息,這個錯誤信息,我們也可以自定義。自定義方式如下:

由于 properties 文件中的中文會亂碼,所以需要我們先修改一下 IDEA 配置,點File?>Settings->Editor?>File Encodings,如下:

https://s3-us-west-2.amazonaws.com/secure.notion-static.com/6901df99-8a2e-418b-b791-77cff9fc1bb7/Untitled.png

然后定義錯誤提示文本,在 resources 目錄下新建一個 MyMessage.properties 文件,內(nèi)容如下:

student.id.notnull=id 不能為空student.name.notnull=name不能為空student.name.length=name最小長度為 2 ,最大長度為10student.email.error=email地址非法student.age.error=年齡不能超過 150

接下來,在 SpringMVC 配置中,加載這個配置文件:

<bean id='validatorFactoryBean'> <property name='providerClass' value='org.hibernate.validator.HibernateValidator'/> <property name='validationMessageSource' ref='bundleMessageSource'/></bean><bean id='bundleMessageSource'> <property name='basenames'> <list> <value>classpath:MyMessage</value> </list> </property> <property name='defaultEncoding' value='UTF-8'/> <property name='cacheSeconds' value='300'/></bean><mvc:annotation-driven validator='validatorFactoryBean'/>

最后,在實體類上,加上校驗出錯時的消息

public class Student { @NotNull(message = '{student.id.notnull}') private Integer id; @NotNull(message = '{student.name.notnull}') @Size(min = 2,max = 10,message = '{student.name.length}') private String name; @Email(message = '{student.email.error}') private String email; @Max(value = 150,message = '{student.age.error}') private Integer age;...}

配置完成后,如果校驗再出錯,就會展示我們自己的出錯信息了。

分組校驗

由于校驗規(guī)則都是定義在實體類上面的,但是,在不同的數(shù)據(jù)提交環(huán)境下,校驗規(guī)則可能不一樣。例如,用戶的 id 是自增長的,添加的時候,可以不用傳遞用戶 id,但是修改的時候則必須傳遞用戶 id,這種情況下,就需要使用分組校驗。

分組校驗,首先需要定義校驗組,所謂的校驗組,其實就是空接口:

public interface ValidationGroup1 {}public interface ValidationGroup2 {}

然后,在實體類中,指定每一個校驗規(guī)則所屬的組:

public class Student { @NotNull(message = '{student.id.notnull}',groups = ValidationGroup1.class) private Integer id; @NotNull(message = '{student.name.notnull}',groups = {ValidationGroup1.class, ValidationGroup2.class}) @Size(min = 2,max = 10,message = '{student.name.length}',groups = {ValidationGroup1.class, ValidationGroup2.class}) private String name; @Email(message = '{student.email.error}',groups = {ValidationGroup1.class, ValidationGroup2.class}) private String email; @Max(value = 150,message = '{student.age.error}',groups = {ValidationGroup2.class}) private Integer age;...}

在 group 中指定每一個校驗規(guī)則所屬的組,一個規(guī)則可以屬于一個組,也可以屬于多個組。

最后,在接收參數(shù)的地方,指定校驗組:

@Controllerpublic class StudentController { @RequestMapping('/addstudent') @ResponseBody public void addStudent(@Validated(ValidationGroup2.class) Student student, BindingResult result) { if (result != null) { //校驗未通過,獲取所有的異常信息并展示出來 List<ObjectError> allErrors = result.getAllErrors(); for (ObjectError allError : allErrors) {System.out.println(allError.getObjectName()+':'+allError.getDefaultMessage()); } } }}

配置完成后,屬于 ValidationGroup2 這個組的校驗規(guī)則,才會生效。

校驗注解

@Null 被注解的元素必須為 null

@NotNull 被注解的元素必須不為 null

@AssertTrue 被注解的元素必須為 true

@AssertFalse 被注解的元素必須為 false

@Min(value) 被注解的元素必須是一個數(shù)字,其值必須大于等于指定的最小值

@Max(value) 被注解的元素必須是一個數(shù)字,其值必須小于等于指定的最大值

@DecimalMin(value) 被注解的元素必須是一個數(shù)字,其值必須大于等于指定的最小值

@DecimalMax(value) 被注解的元素必須是一個數(shù)字,其值必須小于等于指定的最大值

@Size(max=, min=) 被注解的元素的大小必須在指定的范圍內(nèi)

@Digits (integer, fraction) 被注解的元素必須是一個數(shù)字,其值必須在可接受的范圍內(nèi)

@Past 被注解的元素必須是一個過去的日期

@Future 被注解的元素必須是一個將來的日期

@Pattern(regex=,flag=) 被注解的元素必須符合指定的正則表達(dá)式

@NotBlank(message =) 驗證字符串非 null,且長度必須大于0

@Email 被注解的元素必須是電子郵箱地址

@Length(min=,max=) 被注解的字符串的大小必須在指定的范圍內(nèi)

@NotEmpty 被注解的字符串的必須非空

@Range(min=,max=,message=) 被注解的元素必須在合適的范圍內(nèi)

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: Spring
相關(guān)文章:
主站蜘蛛池模板: 真空吸污车_高压清洗车厂家-程力专用汽车股份有限公司官网 | 商用绞肉机-熟肉切片机-冻肉切丁机-猪肉开条机 - 广州市正盈机械设备有限公司 | 蔡司三坐标-影像测量机-3D扫描仪-蔡司显微镜-扫描电镜-工业CT-ZEISS授权代理商三本工业测量 | 电缆隧道在线监测-智慧配电站房-升压站在线监测-江苏久创电气科技有限公司 | elisa试剂盒价格-酶联免疫试剂盒-猪elisa试剂盒-上海恒远生物科技有限公司 | 高压直流电源_特种变压器_变压器铁芯-希恩变压器定制厂家 | led冷热冲击试验箱_LED高低温冲击试验箱_老化试验箱-爱佩百科 | 船用烟火信号弹-CCS防汛救生圈-船用救生抛绳器(海威救生设备) | 智能案卷柜_卷宗柜_钥匙柜_文件流转柜_装备柜_浙江福源智能科技有限公司 | 创绿家招商加盟网-除甲醛加盟-甲醛治理加盟-室内除甲醛加盟-创绿家招商官网 | 上海深蓝_缠绕机_缠膜机-上海深蓝机械装备有限公司 | 环保袋,无纺布袋,无纺布打孔袋,保温袋,环保袋定制,环保袋厂家,环雅包装-十七年环保袋定制厂家 | 蓝莓施肥机,智能施肥机,自动施肥机,水肥一体化项目,水肥一体机厂家,小型施肥机,圣大节水,滴灌施工方案,山东圣大节水科技有限公司官网17864474793 | 电磁流量计厂家_涡街流量计厂家_热式气体流量计-青天伟业仪器仪表有限公司 | 陶瓷砂磨机,盘式砂磨机,棒销式砂磨机-无锡市少宏粉体科技有限公司 | 慈溪麦田广告公司,提供慈溪广告设计。| 3dmax渲染-效果图渲染-影视动画渲染-北京快渲科技有限公司 | 压片机_高速_单冲_双层_花篮式_多功能旋转压片机-上海天九压片机厂家 | 杭州货架订做_组合货架公司_货位式货架_贯通式_重型仓储_工厂货架_货架销售厂家_杭州永诚货架有限公司 | 蔡司三坐标-影像测量机-3D扫描仪-蔡司显微镜-扫描电镜-工业CT-ZEISS授权代理商三本工业测量 | 呼末二氧化碳|ETCO2模块采样管_气体干燥管_气体过滤器-湖南纳雄医疗器械有限公司 | BHK汞灯-百科|上海熙浩实业有限公司| 茶叶百科网-茶叶知识与茶文化探讨分享平台 | 北京百度网站优化|北京网站建设公司-百谷网络科技 | 陕西安闸机-伸缩门-车牌识别-广告道闸——捷申达门业科技 | 办公室家具_板式办公家具定制厂家-FMARTS福玛仕办公家具 | IIS7站长之家-站长工具-爱网站请使用IIS7站长综合查询工具,中国站长【WWW.IIS7.COM】 | 复合土工膜厂家|hdpe防渗土工膜|复合防渗土工布|玻璃纤维|双向塑料土工格栅-安徽路建新材料有限公司 | 深圳市简易检测技术有限公司 | LCD3D打印机|教育|桌面|光固化|FDM3D打印机|3D打印设备-广州造维科技有限公司 | 建筑资质代办-建筑资质转让找上海国信启航 | 石磨面粉机|石磨面粉机械|石磨面粉机组|石磨面粉成套设备-河南成立粮油机械有限公司 | 聚合氯化铝_喷雾聚氯化铝_聚合氯化铝铁厂家_郑州亿升化工有限公司 | 冷藏车厂家|冷藏车价格|小型冷藏车|散装饲料车厂家|程力专用汽车股份有限公司销售十二分公司 | 切铝机-数控切割机-型材切割机-铝型材切割机-【昆山邓氏精密机械有限公司】 | 泰兴市热钻机械有限公司-热熔钻孔机-数控热熔钻-热熔钻孔攻牙一体机 | 水稻烘干机,小麦烘干机,大豆烘干机,玉米烘干机,粮食烘干机_巩义市锦华粮食烘干机械制造有限公司 水环真空泵厂家,2bv真空泵,2be真空泵-淄博真空设备厂 | 无线讲解器-导游讲解器-自助讲解器-分区讲解系统 品牌生产厂家[鹰米讲解-合肥市徽马信息科技有限公司] | 哈尔滨治「失眠/抑郁/焦虑症/精神心理」专科医院排行榜-京科脑康免费咨询 一对一诊疗 | ET3000双钳形接地电阻测试仪_ZSR10A直流_SXJS-IV智能_SX-9000全自动油介质损耗测试仪-上海康登 | 世界箱包品牌十大排名,女包小众轻奢品牌推荐200元左右,男包十大奢侈品牌排行榜双肩,学生拉杆箱什么品牌好质量好 - Gouwu3.com |