实战分析:SpringBoot项目 JSR303校验、Hutool工具类的具体使用

本文主要是介绍实战分析:SpringBoot项目 JSR303校验、Hutool工具类的具体使用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

我是 ABin-阿斌:写一生代码,创一世佳话,筑一览芳华。 如果小伙伴们觉得文章有点 feel ,那就点个赞再走哦。
在这里插入图片描述

声明:

  • 原文地址:https://blog.csdn.net/weixin_51216079/article/details/120413239

  • 原文作者:CSDN:Coder-CT

文章目录

  • 一、前言
  • 二、正文
    • Hutool 相关
      • 代码举例
    • JSR303 相关
      • 代码举例
      • @validated 和 @valid 的区别
        • 嵌套:
    • 全局异常类
      • 自定义返回类

一、前言

  • 在日常开发当中我们会做很多的业务校验,那么我们如果将这些异常有效的返回到页面去跟用户做交互呢?下面我们可以具体卡看看比较常用的几个校验工具。

二、正文

Hutool 相关

  • 引入 Hutool 依赖
   <!--Hutool工具包--><dependency><groupId>cn.hutool</groupId><artifactId>hutool-all</artifactId><version>5.8.4</version></dependency>

代码举例

  • 具体我们可以直接点击到:Assert 断言内部看源码,都是中文注释。基本上看一眼就会了,还是比较简单的。

在这里插入图片描述

  • 当然 Hutool 不单单是用来做断言校验,这个工具类的功能是非常丰富的。 更加详细用法可看官网:Hutool官网
 PsMessageRelease messageFloodControl = this.getById(messageId);Assert.isTrue(ObjectUtils.isNotEmpty(messageFloodControl), "ID为:{},的详情信息不存在!", messageId);PsMessageRelease one = this.getOne(Wrappers.lambdaQuery(PsMessageRelease.class).eq(PsMessageRelease::getTitle, query.getTitle()).eq(PsMessageRelease::getDeleteStatus, DeleteConstant.NOT_DEL).last(MybatisPlusConst.LIMIT_1));Assert.isNull(one, "信息主题不可重复!");

JSR303 相关

  • JSR303 校验不用导入依赖,web 依赖集成了,JSR303 我们一般用来做一些入参的校验。

代码举例

  • 更多相关 API 操作我们可以看官网:JSR303 官网
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

@validated 和 @valid 的区别

  • 在检验 Controller 的入参是否符合规范时,使用 @Validated 或 者@Valid 在基本验证功能上没有太多区别。但是在分组、注解地方、嵌套验证等功能上两个有所不同。
嵌套:
public class Song {@NotNull(message = "id不能为空")@Min(value = 1, message = "id必须为正整数")private Long id;@NotNull(message = "singers不能为空")@Size(min = 1, message = "至少要有一个属性")private List<Singer> singers;
}

注意: Singer 有自己的校验规则 如果 Song 只有 @NotNull 和 @Size 那么 Singer 里面的属性就没法校验

public class Singer{@NotNull(message = "id不能为空")@Min(value = 1, message = "id必须为正整数")private Long id;@NotNull(message = "vid不能为空")@Min(value = 1, message = "vid必须为正整数")private Long vid;@NotBlank(message = "pidName不能为空")private String pidName;@NotBlank(message = "vidName不能为空")private String vidName;
}
@RestController
public class ItemController {@RequestMapping("/song /add")public void addSong(@RequestBody @Validated Song song) {System.out.println(song);}
}
  • 这里只会校验 singer 里面的字段数量和非空校验,不会对 singer 字段里的 Singer 实体进行字段验证,也就是 @Validated 和@Valid 加在方法参数前,都不会对参数进行嵌套验证。

  • Song 更新一下代码

public class Song {@NotNull(message = "id不能为空")@Min(value = 1, message = "id必须为正整数")private Long id;@Valid // 嵌套验证必须用@Valid@NotNull(message = "singers不能为空")@Size(min = 1, message = "至少要有一个属性")private List<Singer> singers;
}

细节点注意:

  • @Validated:提供了一个分组功能,可以在入参验证时,根据不同的分组采用不同的验证机制
  • @Validated:只能用在类、方法和方法参数上 ,不能用在字段上!
  • @Valid:作为标准JSR-303规范,不会进行分组校验,直接校验字段
  • 新增或修改的时候就需要进行分组校验
@Data
@TableName("hss_equipment")
public class Equipment implements Serializable {private static final long serialVersionUID = 1L;/*** id*/@NotNull(message = "修改必须指定id",groups = {UpdateGroup.class})//只有在修改的时候才会触发@Null(message = "新增不能指定id",groups = {AddGroup.class})//只有在新增的时候才会触发@TableIdprivate Long Id;

指定两个分组接口 ,不需要实现,这两个接口需要打在接口上面,用于区分

// 添加的分组校验接口
public interface AddGroup {
}// 修改的分组校验接口
public interface UpdateGroup {
}

使用@Validated指定分组 只有指定了分组的字段才会生效

/*** 保存*/@RequestMapping("/save")public R save(@Validated({AddGroup.class}) @RequestBody Equipment equipment) {brandService.save(brand);return R.ok();}/*** 修改*/@RequestMapping("/update")public R update(@Validated({UpdateGroup.class})@RequestBody Equipment equipment) {brandService.updateById(brand);return R.ok();}

全局异常类

import com.molomessage.message.sys.service.EmailService;
import com.molomessage.message.sys.utils.R;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.validation.BindException;
import org.springframework.validation.BindingResult;
import org.springframework.web.bind.MethodArgumentNotValidException;
import org.springframework.web.bind.annotation.ExceptionHandler;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.bind.annotation.RestControllerAdvice;import javax.servlet.http.HttpServletRequest;
import java.io.*;
import java.text.SimpleDateFormat;/*** chen* 2021-* 全局异常* 该注解会 适用所有的@RequestMapper() 结合@ExceptionHander 实现全局异常处理*/
@RestControllerAdvice
@ResponseBody
public class GlobalExceptionHandler {@Autowiredprivate EmailService emailService;private final static Logger log = LoggerFactory.getLogger(GlobalExceptionHandler.class);//jsr303校验全局异常@ExceptionHandler(value = {MethodArgumentNotValidException.class, BindException.class}) /*定义拦截*/public R exceptionHandler(HttpServletRequest request, Exception e) {BindingResult bindingResult = null;if (e instanceof MethodArgumentNotValidException) {bindingResult = ((MethodArgumentNotValidException) e).getBindingResult();} else if (e instanceof BindException) {bindingResult = ((BindException) e).getBindingResult();}StringBuffer buffer = new StringBuffer();//获取全部异常信息bindingResult.getFieldErrors().forEach(fieldError ->buffer.append(fieldError.getDefaultMessage() + ","));return R.error(buffer.toString());}//hutool断言全局异常处理@ExceptionHandler(value = {IllegalArgumentException.class}) /*定义拦截*/public R hutoolHandler(HttpServletRequest request, Exception e) {return R.error(e.getMessage());}//其它异常信息@ExceptionHandler(value = Exception.class)public R exception(Exception e) {e.printStackTrace();SimpleDateFormat sf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");final String format = sf.format(new java.util.Date());StackTraceElement[] stackTrace = e.getStackTrace();//发送邮件内容StringBuffer buffer = new StringBuffer();buffer.append("异常类型:" + e + ",\n");if (e.getMessage() != null) buffer.append("异常原因:" + e.getMessage() + ",\n");//类名buffer.append("类名:" + stackTrace[0].getClassName() + ",\n");//文件名buffer.append("文件名:" + stackTrace[0].getFileName() + ",\n");//方法名buffer.append("方法名:" + stackTrace[0].getMethodName() + ",\n");//具体哪一行报的错buffer.append("报错行数:" + stackTrace[0].getLineNumber() + ",\n");buffer.append(format + "\n");//当前系统时间buffer.append(" \n");//换行//发送邮件给管理员//emailService.emailSend("8048984@qq.com", "业务异常", buffer.toString());//异常信息写出到文件中try {//以追加的形式写入文件中FileOutputStream stream = new FileOutputStream("F:/logs/java全局异常信息.txt", true);try {stream.write(buffer.toString().getBytes());stream.close();} catch (IOException ex) {ex.printStackTrace();}} catch (FileNotFoundException ex) {ex.printStackTrace();}return R.error("服务器异常").put("异常类型", e.toString()).put("异常原因",e.getMessage()).put("异常文件名", stackTrace[0].getFileName()).put("异常方法名", stackTrace[0].getMethodName()).put("异常行数", stackTrace[0].getLineNumber());}}

自定义返回类

import java.util.HashMap;
import java.util.Map;/*** 返回数据* * @author chen* @date 2021年*/
public class R extends HashMap<String, Object> {private static final long serialVersionUID = 1L;public R() {put("success",true);put("code", 0);put("msg","操作成功");}public static R error() {return error(500, "未知异常,请联系管理员");}public static R error(String msg) {return error(500, msg);}public static R error(int code, String msg) {R r = new R();r.put("code", code);r.put("msg", msg);r.put("success",false);return r;}public static R ok(String msg, Object obj) {R r = new R();r.put("success",true);r.put("msg", msg);r.put("data", obj);return r;}public static R ok(String msg) {R r = new R();r.put("success",true);r.put("msg", msg);return r;}public static R ok(Map<String, Object> map) {R r = new R();r.putAll(map);return r;}public static R ok() {return new R();}public R put(String key, Object value) {super.put(key, value);return this;}
}

这篇关于实战分析:SpringBoot项目 JSR303校验、Hutool工具类的具体使用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/428450

相关文章

网页解析 lxml 库--实战

lxml库使用流程 lxml 是 Python 的第三方解析库,完全使用 Python 语言编写,它对 XPath表达式提供了良好的支 持,因此能够了高效地解析 HTML/XML 文档。本节讲解如何通过 lxml 库解析 HTML 文档。 pip install lxml lxm| 库提供了一个 etree 模块,该模块专门用来解析 HTML/XML 文档,下面来介绍一下 lxml 库

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

Spring Security--Architecture Overview

1 核心组件 这一节主要介绍一些在Spring Security中常见且核心的Java类,它们之间的依赖,构建起了整个框架。想要理解整个架构,最起码得对这些类眼熟。 1.1 SecurityContextHolder SecurityContextHolder用于存储安全上下文(security context)的信息。当前操作的用户是谁,该用户是否已经被认证,他拥有哪些角色权限…这些都被保

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Java架构师知识体认识

源码分析 常用设计模式 Proxy代理模式Factory工厂模式Singleton单例模式Delegate委派模式Strategy策略模式Prototype原型模式Template模板模式 Spring5 beans 接口实例化代理Bean操作 Context Ioc容器设计原理及高级特性Aop设计原理Factorybean与Beanfactory Transaction 声明式事物

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

中文分词jieba库的使用与实景应用(一)

知识星球:https://articles.zsxq.com/id_fxvgc803qmr2.html 目录 一.定义: 精确模式(默认模式): 全模式: 搜索引擎模式: paddle 模式(基于深度学习的分词模式): 二 自定义词典 三.文本解析   调整词出现的频率 四. 关键词提取 A. 基于TF-IDF算法的关键词提取 B. 基于TextRank算法的关键词提取