【WEEK9】 【DAY3】JSR303数据校验及多环境切换【中文版】

2024-04-25 09:36

本文主要是介绍【WEEK9】 【DAY3】JSR303数据校验及多环境切换【中文版】,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

2024.4.24 Wednesday

目录

  • 4.JSR303数据校验及多环境切换
    • 4.1.JSR303数据校验(了解即可)
      • 4.1.1.修改Person.java
      • 4.1.2.修改pom.xml(添加依赖)
      • 4.1.3.运行Springboot02ConfigApplicationTests.java进行测试
      • 4.1.4.使用数据校验(后端),可以保证数据的正确性
      • 4.1.5.常见参数
    • 4.2.多环境切换
      • 4.2.1.将本项目冗余文件删除
      • 4.2.2.多配置文件
        • 例如
      • 4.2.3.Yaml的多文档块
        • 4.2.3.1.和properties配置文件中一样,但是使用yml去实现不需要创建多个配置文件,更加方便了
        • 4.2.3.2.注意:如果yml和properties同时都配置了端口,并且没有激活其他环境,默认会使用properties配置文件的!(删除.properties文件)
      • 4.2.4.配置文件加载位置
        • 4.2.4.1.外部加载配置文件(添加application.yaml文件的有效地址)的方式十分多,我们选择最常用的即可,在开发的资源文件中进行配置!
        • 4.2.4.2.springboot 启动会扫描以下位置的application.properties或者application.yml文件作为Spring boot的默认配置文件:
      • 4.2.5.拓展,运维小技巧

4.JSR303数据校验及多环境切换

4.1.JSR303数据校验(了解即可)

4.1.1.修改Person.java

添加两个依赖(@Validated和@Email)

package com.p8.springboot02config.pojo;import org.springframework.beans.factory.annotation.Value;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.context.annotation.PropertySource;
import org.springframework.stereotype.Component;
import org.springframework.validation.annotation.Validated;import javax.validation.constraints.Email;
import java.util.Date;
import java.util.List;
import java.util.Map;@Component  //注册bean
@ConfigurationProperties(prefix = "person")
@Validated  //数据校验public class Person {//这里没有@Email注解提示的和@Email注解报错的去添加一下hibernate-validator依赖@Email()    //在括号内书写message = "格式错误"则报错时的提示信息会变更为"格式错误"private String name;    //提示,可以使用 shift + f6 实现所有的名称一起改private Integer age;private Boolean happy;private Date birth;private Map<String,Object> maps;private List<Object> lists;private Dog dog;...
}

4.1.2.修改pom.xml(添加依赖)

<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-validation</artifactId>
</dependency>

4.1.3.运行Springboot02ConfigApplicationTests.java进行测试

在这里插入图片描述
在这里插入图片描述

4.1.4.使用数据校验(后端),可以保证数据的正确性

4.1.5.常见参数

@NotNull(message="名字不能为空")
private String userName;
@Max(value=120,message="年龄最大不能查过120")
private int age;
@Email(message="邮箱格式错误")
private String email;空检查
@Null       验证对象是否为null
@NotNull    验证对象是否不为null, 无法查检长度为0的字符串
@NotBlank   检查约束字符串是不是Null还有被Trim的长度是否大于0,只对字符串,且会去掉前后空格.
@NotEmpty   检查约束元素是否为NULL或者是EMPTY.Booelan检查
@AssertTrue     验证 Boolean 对象是否为 true  
@AssertFalse    验证 Boolean 对象是否为 false长度检查
@Size(min=, max=) 验证对象(Array,Collection,Map,String)长度是否在给定的范围之内  
@Length(min=, max=) string is between min and max included.日期检查
@Past       验证 Date 和 Calendar 对象是否在当前时间之前  
@Future     验证 Date 和 Calendar 对象是否在当前时间之后  
@Pattern    验证 String 对象是否符合**正则表达式**的规则

…等等
除此以外,我们还可以自定义一些数据校验规则
在这里插入图片描述

4.2.多环境切换

4.2.1.将本项目冗余文件删除

如下:
在这里插入图片描述
清空application.yaml和Springboot02ConfigApplicationTests.java文件内容
profile是Spring对不同环境提供不同配置功能的支持,可以通过激活不同的环境版本,实现快速切换环境。

4.2.2.多配置文件

我们在主配置文件编写的时候,文件名可以是 application-{profile}.properties/yml , 用来指定多个环境版本。

例如

(创建: application.properties, application-test.properties, application-dev.properties)
在这里插入图片描述

application-test.properties代表测试环境配置
server.port=8081
application-dev.properties代表开发环境配置
server.port=8082

但是Springboot并不会直接启动这些配置文件,它默认使用application. properties主配置文件
在这里插入图片描述

->我们需要通过一个配置来选择需要激活的环境:

#比如在配置文件中指定使用dev环境,我们可以通过设置不同的端口号进行测试;
#我们启动SpringBoot,就可以看到已经切换到dev下的配置了;
spring.profiles.active=dev

在这里插入图片描述

如果把dev更改成test,则运行application-test.properties
在这里插入图片描述

4.2.3.Yaml的多文档块

4.2.3.1.和properties配置文件中一样,但是使用yml去实现不需要创建多个配置文件,更加方便了

新建application.yaml
在这里插入图片描述

server:port: 8081  #默认
#选择要激活那个环境块
spring:profiles:active: prod---
server:port: 8083
spring:profiles: dev #配置环境的名称---server:port: 8084
spring:profiles: prod  #配置环境的名称
4.2.3.2.注意:如果yml和properties同时都配置了端口,并且没有激活其他环境,默认会使用properties配置文件的!(删除.properties文件)

在这里插入图片描述

4.2.4.配置文件加载位置

4.2.4.1.外部加载配置文件(添加application.yaml文件的有效地址)的方式十分多,我们选择最常用的即可,在开发的资源文件中进行配置!

https://docs.spring.io/spring-boot/docs/2.7.13/reference/htmlsingle/#features.external-config
在这里插入图片描述
故优先级最高的是下图中红框部分的内容
在这里插入图片描述
新建文件夹后需要修改文件夹类型
在这里插入图片描述

4.2.4.2.springboot 启动会扫描以下位置的application.properties或者application.yml文件作为Spring boot的默认配置文件:
  • 优先级1:项目路径下的config文件夹配置文件(src/main/resources/config/application.yaml)
#src/main/resources/config/application.yaml
server:port: 8081

在这里插入图片描述

  • 优先级2:项目路径下配置文件(src/main/resources/application.yaml)
删除上一个优先级的文件后运行的就是这个了,后面的操作也是相同(删除配置文件后要刷新一下maven)
#src/main/resources/application.yaml
server:port: 8082

在这里插入图片描述

  • 优先级3:资源路径下的config文件夹配置文件(config/application.yaml)
#config/application.yaml
server:port: 8083

在这里插入图片描述

  • 优先级4:资源路径下配置文件(application.yaml)
#application.yaml
server:port: 8084

在这里插入图片描述
这里可能无法自动识别application文件(显示红色的yml图标,如:
在这里插入图片描述
),如何修改成绿色豌豆射手状?
修改Project Settings->Modules->找到该项目->修改成resources类型
在这里插入图片描述
优先级由高到底,高优先级的配置会覆盖低优先级的配置;
SpringBoot会从这四个位置全部加载主配置文件;互补配置。

4.2.5.拓展,运维小技巧

指定位置加载配置文件
我们还可以通过spring.config.location来改变默认的配置文件位置
项目打包好以后,我们可以使用命令行参数的形式,启动项目的时候来指定配置文件的新位置;这种情况,一般是后期运维做的多,相同配置,外部指定的配置文件优先级最高

java -jar spring-boot-config.jar --spring.config.location=F:/application.properties

这篇关于【WEEK9】 【DAY3】JSR303数据校验及多环境切换【中文版】的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

大模型研发全揭秘:客服工单数据标注的完整攻略

在人工智能(AI)领域,数据标注是模型训练过程中至关重要的一步。无论你是新手还是有经验的从业者,掌握数据标注的技术细节和常见问题的解决方案都能为你的AI项目增添不少价值。在电信运营商的客服系统中,工单数据是客户问题和解决方案的重要记录。通过对这些工单数据进行有效标注,不仅能够帮助提升客服自动化系统的智能化水平,还能优化客户服务流程,提高客户满意度。本文将详细介绍如何在电信运营商客服工单的背景下进行

基于MySQL Binlog的Elasticsearch数据同步实践

一、为什么要做 随着马蜂窝的逐渐发展,我们的业务数据越来越多,单纯使用 MySQL 已经不能满足我们的数据查询需求,例如对于商品、订单等数据的多维度检索。 使用 Elasticsearch 存储业务数据可以很好的解决我们业务中的搜索需求。而数据进行异构存储后,随之而来的就是数据同步的问题。 二、现有方法及问题 对于数据同步,我们目前的解决方案是建立数据中间表。把需要检索的业务数据,统一放到一张M

关于数据埋点,你需要了解这些基本知识

产品汪每天都在和数据打交道,你知道数据来自哪里吗? 移动app端内的用户行为数据大多来自埋点,了解一些埋点知识,能和数据分析师、技术侃大山,参与到前期的数据采集,更重要是让最终的埋点数据能为我所用,否则可怜巴巴等上几个月是常有的事。   埋点类型 根据埋点方式,可以区分为: 手动埋点半自动埋点全自动埋点 秉承“任何事物都有两面性”的道理:自动程度高的,能解决通用统计,便于统一化管理,但个性化定

使用SecondaryNameNode恢复NameNode的数据

1)需求: NameNode进程挂了并且存储的数据也丢失了,如何恢复NameNode 此种方式恢复的数据可能存在小部分数据的丢失。 2)故障模拟 (1)kill -9 NameNode进程 [lytfly@hadoop102 current]$ kill -9 19886 (2)删除NameNode存储的数据(/opt/module/hadoop-3.1.4/data/tmp/dfs/na

异构存储(冷热数据分离)

异构存储主要解决不同的数据,存储在不同类型的硬盘中,达到最佳性能的问题。 异构存储Shell操作 (1)查看当前有哪些存储策略可以用 [lytfly@hadoop102 hadoop-3.1.4]$ hdfs storagepolicies -listPolicies (2)为指定路径(数据存储目录)设置指定的存储策略 hdfs storagepolicies -setStoragePo

Hadoop集群数据均衡之磁盘间数据均衡

生产环境,由于硬盘空间不足,往往需要增加一块硬盘。刚加载的硬盘没有数据时,可以执行磁盘数据均衡命令。(Hadoop3.x新特性) plan后面带的节点的名字必须是已经存在的,并且是需要均衡的节点。 如果节点不存在,会报如下错误: 如果节点只有一个硬盘的话,不会创建均衡计划: (1)生成均衡计划 hdfs diskbalancer -plan hadoop102 (2)执行均衡计划 hd

阿里开源语音识别SenseVoiceWindows环境部署

SenseVoice介绍 SenseVoice 专注于高精度多语言语音识别、情感辨识和音频事件检测多语言识别: 采用超过 40 万小时数据训练,支持超过 50 种语言,识别效果上优于 Whisper 模型。富文本识别:具备优秀的情感识别,能够在测试数据上达到和超过目前最佳情感识别模型的效果。支持声音事件检测能力,支持音乐、掌声、笑声、哭声、咳嗽、喷嚏等多种常见人机交互事件进行检测。高效推

【Prometheus】PromQL向量匹配实现不同标签的向量数据进行运算

✨✨ 欢迎大家来到景天科技苑✨✨ 🎈🎈 养成好习惯,先赞后看哦~🎈🎈 🏆 作者简介:景天科技苑 🏆《头衔》:大厂架构师,华为云开发者社区专家博主,阿里云开发者社区专家博主,CSDN全栈领域优质创作者,掘金优秀博主,51CTO博客专家等。 🏆《博客》:Python全栈,前后端开发,小程序开发,人工智能,js逆向,App逆向,网络系统安全,数据分析,Django,fastapi

安装nodejs环境

本文介绍了如何通过nvm(NodeVersionManager)安装和管理Node.js及npm的不同版本,包括下载安装脚本、检查版本并安装特定版本的方法。 1、安装nvm curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.0/install.sh | bash 2、查看nvm版本 nvm --version 3、安装

烟火目标检测数据集 7800张 烟火检测 带标注 voc yolo

一个包含7800张带标注图像的数据集,专门用于烟火目标检测,是一个非常有价值的资源,尤其对于那些致力于公共安全、事件管理和烟花表演监控等领域的人士而言。下面是对此数据集的一个详细介绍: 数据集名称:烟火目标检测数据集 数据集规模: 图片数量:7800张类别:主要包含烟火类目标,可能还包括其他相关类别,如烟火发射装置、背景等。格式:图像文件通常为JPEG或PNG格式;标注文件可能为X