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

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

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

瀏覽:117日期: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
主站蜘蛛池模板: 国产美女久久久 | 久久激情五月丁香伊人 | 午夜宅男宅女的免费网站 | 一级视频在线 | 欧美一级毛片特黄黄 | 欧美aaa级片 | 亚洲欧美v| 欧美日产国产亚洲综合图区一 | 日日操狠狠干 | 1024免费在线观看 | 国产91小视频在线观看 | 国产99免费视频 | 五月天婷婷一区二区三区久久 | 正在播放一区 | 2020国产精品亚洲综合网 | 国产自愉怕一区二区三区 | 动漫男女交性动漫网站 | 欧美一区二区三区播放 | 一级a性色生活片毛片 | 黄视频网站免费看 | 中文字幕亚洲欧美日韩不卡 | a级毛片免费高清毛片视频 a级毛片免费播放 | 黄色激情毛片 | 日韩精品一区在线 | 国产精品久久久久激情影院 | 一级一级毛片 | 日韩精品欧美视频 | 成人影院www在线观看 | 国产精品亚洲一区在线播放 | 视频二区精品中文字幕 | 日本久久影视 | 国产精品久久久久久麻豆一区 | 成人亚洲在线 | 成年超爽大片免费视频播放 | 色在线观看视频 | 欧美成人性毛片免费版 | 亚洲视频网址 | 欧美日韩高清一本大道免费 | 亚洲国产精品aa在线看 | 日韩欧美亚洲综合久久99e | 欧美人与善交大片 |