亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

java - SpringMVC集成hibernate validator進行參數驗證時,為什么不直接拋異常?

瀏覽:96日期:2023-10-27 14:01:40

問題描述

各位大神好,請教個問題

1.環境

spring 4.3.7hibernate-validator-5.4.1

2.配置如下

<bean name='messageSource'><property name='basenames'> <list><value>classpath:messages/messages</value><value>classpath:messages/ValidationMessages</value> </list></property><property name='useCodeAsDefaultMessage' value='false' /><property name='defaultEncoding' value='UTF-8' /><property name='cacheSeconds' value='60' /> </bean> <bean class='org.springframework.validation.beanvalidation.LocalValidatorFactoryBean'><property name='providerClass' value='org.hibernate.validator.HibernateValidator'/><property name='validationMessageSource' ref='messageSource'/> </bean> <mvc:annotation-driven validator='validator' />

3.bean和Controller

public class UserRequest {@NotBlank(message = '{login.valid.username.notnull}') private String username;@NotBlank(message = '{login.valid.password.notnull}') private String password; public String getUsername() {return username; } public void setUsername(String username) {this.username = username; } public String getPassword() {return password; } public void setPassword(String password) {this.password = password; }}

@RequestMapping(value = '/login', method = RequestMethod.POST) @ResponseBody public Object login(@Valid @RequestBody UserRequest ur, BindingResult result, HttpServletRequest request) {log.debug('login');if(result.hasErrors()) { return result.getAllErrors().get(0); } …… }

問題:為什么一定要在代碼中用result.hasErrors()顯示判斷?難道不能驗證UserRequest中的字段不符合定義就直接拋異常,這樣不更合理些嗎?

問題解答

回答1:

問題:為什么一定要在代碼中用result.hasErrors()顯示判斷?難道不能驗證UserRequest中的字段不符合定義就直接拋異常,這樣不更合理些嗎?

例如我們在參數異常的時候返回給前端的是異常的具體參數名和描述,不是 Spring 給出的所有異常信息,如果 Spring 自動拋出異常,那么返回的信息你自己就不好控制了。

@PostMapping(UriView.REST_KNOWLEDGE_POINTS)@ResponseBodypublic Result createKnowledgePoint(@Valid KnowledgePoint knowledgePoint, BindingResult bindingResult) { // 如有參數錯誤,則返回錯誤信息給客戶端 if (bindingResult.hasErrors()) {return Result.fail(CommonUtils.getBindingMessage(bindingResult)); } knowledgePoint.setKnowledgePointId(CommonUtils.uuid()); knowledgePoint.setName(knowledgePoint.getName().trim()); mapper.createKnowledgePoint(knowledgePoint); return Result.ok('', knowledgePoint);}/** * BindingResult 中的錯誤信息很多,對用戶不夠友好,使用 getBindingMessage() * 提取對用戶閱讀友好的定義驗證規則 message。 * * @param result 驗證的結果對象 * @return 驗證規則 message */public static String getBindingMessage(BindingResult result) { StringBuffer sb = new StringBuffer(); for (FieldError error : result.getFieldErrors()) {// sb.append(error.getField() + ' : ' + error.getDefaultMessage() + 'n');sb.append(error.getDefaultMessage() + 'n'); } return sb.toString();}回答2:

你只是在你的應用場景中考慮為什么,一個框架更多的是考慮大多數時候怎么做最合理。

大部分對于客戶端數據的驗證都不應當被當作“異常”,而是用戶在不知道的情況下被允許犯的錯誤。

標簽: java
主站蜘蛛池模板: 欧美精品日本一级特黄 | 一级女性全黄生活片看看 | a级国产乱理论片在线观看看 | 国产污| 免费视频一区二区 | 很黄很黄的毛片欧美 | 日本一级特黄aa大片在线观看 | 成人午夜在线观看国产 | 色成人在线| 亚洲国产m3u8在线观看 | 福利社区在线观看 | 日韩免费一区二区三区 | 日韩经典欧美一区二区三区 | 日本一级特黄a大片在线 | 色婷婷影院 | 看黄色小视频 | 久久久受www免费人成 | 亚洲邪恶天堂影院在线观看 | 精品在线视频免费 | 播放欧亚一级特黄录像 | 国产原创麻豆 | 最新露脸国产精品视频 | 久久综合中文字幕一区二区 | 久热re国产手机在线观看 | 99国产精品热久久久久久夜夜嗨 | 清纯唯美亚洲综合五月天 | 91精品国产亚一区二区三区 | 国产精品亚洲欧美云霸高清 | 国产欧美日韩在线 | 国产一区二区在线观看视频 | 青青热久免费精品视频在首页 | 国产一区二区不卡视频 | 日本高清二三四本2021 | 国产福利视频在线播放 | 国产精品自拍一区 | 成年人黄色网址 | 欧美日韩另类国产 | 我想看黄色一级片 | 成人在线小视频 | 国产黄色三级三级三级 | 91久久亚洲精品一区二区 |