Java学习笔记(二十三)
1 @CacheEvict
@CacheEvict是Spring框架中用于清空缓存的注解。以下是对@CacheEvict注解的详细介绍:
1.1 作用
@CacheEvict注解的主要作用是删除缓存中的数据。在方法执行后或执行前(根据配置),它可以清空指定的缓存项或整个缓存区域。这对于删除旧的数据或无效的数据非常有用,可以确保缓存中的数据始终是最新的。
1.2 常用属性
@CacheEvict注解包含多个属性,用于配置缓存删除的行为:
- value/cacheNames:指定要清空的缓存的名称。可以是一个字符串或一个字符串数组,表示该方法将清空哪个缓存区域中的数据。如果指定了多个缓存名称,那么这些缓存区域中的数据都将被清空。
- key:指定要清空的缓存项的键。通过该属性,可以精确控制要删除的缓存数据。可以使用SpEL表达式来动态生成键的值。
- allEntries:一个布尔值,用于指定是否清空缓存中的所有数据。如果设置为true,那么将删除指定缓存区域中的所有数据;如果设置为false(默认值),则只删除与指定键相匹配的缓存项。
- beforeInvocation:一个布尔值,用于指定是否在方法执行前清空缓存。如果设置为true,那么缓存的清空操作将在方法执行之前进行;如果设置为false(默认值),则缓存的清空操作将在方法执行之后进行。需要注意的是,如果在方法执行前清空缓存,并且方法执行失败(抛出异常),那么缓存将不会被重新填充。
1.3 使用示例
以下是一个使用@CacheEvict注解的示例:
@Service
public class UserService {@Autowiredprivate UserRepository userRepository;// 使用@Cacheable注解缓存用户数据@Cacheable(value = "users", key = "#id")public User getUserById(Long id) {return userRepository.findById(id).orElse(null);}// 使用@CacheEvict注解删除用户数据对应的缓存@CacheEvict(value = "users", key = "#user.id")public void saveUser(User user) {userRepository.save(user);}
}
在上面的示例中,UserService类中的getUserById方法使用了@Cacheable注解来缓存用户数据。而saveUser方法则使用了@CacheEvict注解来删除与保存的用户数据相对应的缓存项。这样,在每次保存用户数据后,都可以确保缓存中的数据是最新的。
1.4 注意事项
- 在使用@CacheEvict注解时,必须指定要清空的缓存名称(value/cacheNames属性)和缓存项的键(key属性)。
- 如果指定了allEntries属性为true,那么将删除指定缓存区域中的所有数据,因此需要谨慎使用。
- 如果在方法执行前清空缓存(beforeInvocation属性为true),并且方法执行失败,那么缓存将不会被重新填充。这可能会导致在某些情况下出现数据不一致的问题。因此,在使用beforeInvocation属性时,需要充分考虑方法的执行情况和可能的异常处理。
总之,@CacheEvict注解是Spring框架中用于清空缓存的重要工具。通过合理配置其属性,可以实现对缓存数据的精确控制和管理。
2 @Caching
@Caching注解是Spring Cache提供的一个功能强大的组合注解,它允许开发者在一个方法或类上同时指定多个缓存操作相关的注解。以下是关于@Caching注解的详细介绍:
2.1 @Caching注解的主要功能
@Caching注解通过组合多个Spring Cache注解(如@Cacheable、@CachePut、@CacheEvict等),能够定义复杂的缓存规则。这使得开发者可以在一个方法上灵活地配置多种缓存行为,而无需编写重复的缓存处理代码。
2.2 @Caching注解的属性
@Caching注解拥有三个主要属性,每个属性都可以接收一个或多个相应的注解作为值:
- cacheable:用于指定一个或多个@Cacheable注解的组合。@Cacheable注解用于查询缓存,如果缓存中存在相应的数据,则直接返回缓存数据而不执行方法。如果没有缓存数据,则执行方法并将结果添加到缓存中。
- put:用于指定一个或多个@CachePut注解的组合。@CachePut注解无论方法是否被执行,都会将方法的返回值放入指定的缓存中。这通常用于更新缓存数据。
- evict:用于指定一个或多个@CacheEvict注解的组合。@CacheEvict注解用于删除缓存中的数据,通常用于删除操作或数据更新后的缓存同步。
2.3 @Caching注解的使用示例
以下是一个使用@Caching注解的示例,展示了如何在一个方法上同时指定查询缓存、更新缓存和删除缓存的操作:
@Caching(cacheable = @Cacheable(key = "'userCache:'+ #uid"),put = @CachePut(key = "'userCache:'+ #uid"),evict = { @CacheEvict(key = "'userCache:'+ #uid"), @CacheEvict(key = "'addressCache:'+ #uid"), @CacheEvict(key = "'messageCache:'+ #uid") }
)
public User updateRef(String uid) {// 业务逻辑return null;
}
在这个示例中,updateRef
方法被配置了多个缓存操作:
- 使用@Cacheable注解查询
userCache
缓存,如果缓存中存在以uid
为键的数据,则直接返回该数据。 - 使用@CachePut注解更新
userCache
缓存,将方法的返回值放入缓存中。 - 使用多个@CacheEvict注解删除
userCache
、addressCache
和messageCache
缓存中以uid
为键的数据。
2.4 @Caching注解的注意事项
- SpEL表达式:在@Caching注解的属性中,可以使用Spring Expression Language(SpEL)表达式来动态生成缓存的键(key)。这提供了很大的灵活性,允许开发者根据方法的参数或返回值来定制缓存的键。
- 缓存配置:在使用@Caching注解之前,需要确保已经配置了Spring Cache的相关依赖和缓存管理器(CacheManager)。这通常通过在Spring Boot应用程序的主类或配置类上使用@EnableCaching注解来启用缓存支持,并通过application.properties或application.yml文件进行自定义配置。
- 缓存同步:在使用@Cacheable和@CachePut注解时,需要注意缓存的同步问题。如果多个线程同时访问同一个缓存键,可能会导致数据不一致的问题。因此,在使用这些注解时,需要确保缓存的同步机制得到妥善处理。
综上所述,@Caching注解是Spring Cache提供的一个非常有用的工具,它允许开发者在一个方法或类上同时指定多个缓存操作相关的注解。通过合理使用@Caching注解,可以大大提高应用程序的性能和可维护性。
3 @After 、@Before 、@ Around
@After
、@Before
和 @Around
是Spring AOP(面向切面编程)中的注解,它们用于定义切面的通知(Advice),这些通知在目标方法执行的不同阶段执行额外的逻辑。以下是这些注解的详细介绍及示例:
3.1 @Before
注解
- 作用:前置通知,在目标方法执行之前执行。它通常用于执行一些前置条件检查、日志记录等。
- 示例:
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Before;
import org.springframework.stereotype.Component;@Aspect
@Component
public class MyBeforeAdvice {@Before("execution(* com.example.service.*.*(..))")public void beforeAdvice() {System.out.println("Before method execution");// 在这里可以执行前置逻辑,如日志记录、权限检查等}
}
在这个例子中,beforeAdvice
方法会在 com.example.service
包下所有类的所有方法执行之前执行。
3.2 @After
注解
- 作用:后置通知,在目标方法执行之后执行,无论目标方法是否抛出异常。它通常用于执行一些清理工作、日志记录等。
- 示例:
import org.aspectj.lang.annotation.After;
import org.aspectj.lang.JoinPoint;
import org.aspectj.lang.annotation.Aspect;
import org.springframework.stereotype.Component;@Aspect
@Component
public class MyAfterAdvice {@After("execution(* com.example.service.*.*(..))")public void afterAdvice(JoinPoint joinPoint) {System.out.println("After method execution: " + joinPoint.getSignature());// 在这里可以执行后置逻辑,如日志记录、资源释放等}
}
在这个例子中,afterAdvice
方法会在 com.example.service
包下所有类的所有方法执行之后执行。
3.3 @Around
注解
- 作用:环绕通知,可以包裹目标方法的执行,拥有最大的控制权。它可以在目标方法执行前后执行自定义逻辑,甚至可以决定是否继续执行目标方法或改变其返回值。
- 示例:
import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.annotation.Around;
import org.aspectj.lang.annotation.Aspect;
import org.springframework.stereotype.Component;@Aspect
@Component
public class MyAroundAdvice {@Around("execution(* com.example.service.*.*(..))")public Object aroundAdvice(ProceedingJoinPoint pjp) throws Throwable {System.out.println("Before method execution");try {Object result = pjp.proceed(); // 执行目标方法System.out.println("After method execution");return result; // 返回目标方法的执行结果} catch (Throwable throwable) {// 处理异常System.out.println("Exception occurred: " + throwable.getMessage());throw throwable; // 重新抛出异常}}
}
在这个例子中,aroundAdvice
方法会在 com.example.service
包下所有类的所有方法执行前后执行自定义逻辑。它首先打印“Before method execution”,然后执行目标方法,并打印“After method execution”。如果目标方法抛出异常,它还会捕获并处理该异常。
3.4 总结
@Before
注解用于在目标方法执行之前执行前置逻辑。@After
注解用于在目标方法执行之后执行后置逻辑,无论目标方法是否抛出异常。@Around
注解用于在目标方法执行前后执行自定义逻辑,并可以控制是否继续执行目标方法或改变其返回值。
这些注解在Spring AOP中非常有用,可以帮助开发者在不修改目标方法代码的情况下实现各种复杂的功能和逻辑。
4 docker network
Docker提供了一组命令来管理和配置Linux网络,这些命令可以创建、列出、删除和检查网络,帮助用户在Docker容器之间建立通信。以下是一些常用的Docker网络命令及其详细介绍:
4.1 创建网络
-
命令:
docker network create [OPTIONS] NETWORK_NAME
-
功能:创建一个新的Docker网络。
-
选项:
--driver
:指定网络驱动程序(如bridge、host、overlay等)。--subnet
:指定子网。--gateway
:指定网关。--ip-range
:指定可用IP地址范围。--ipv6
:启用IPv6。--label
:为网络添加标签。
-
示例:
docker network create --driver bridge --subnet 192.168.1.0/24 my_network
4.2 列出网络
- 命令:
docker network ls
- 功能:列出所有可用的Docker网络。
- 输出:包括NETWORK ID、NAME、DRIVER和SCOPE等信息。
4.3 查看网络详情
- 命令:
docker network inspect [OPTIONS] NETWORK_NAME
- 功能:查看指定Docker网络的详细信息。
- 输出:包括网络名称、ID、创建时间、作用域、驱动程序、IPAM配置(子网、网关等)、容器连接信息等。
4.4 连接容器到网络
-
命令:
docker network connect [OPTIONS] NETWORK_NAME CONTAINER_NAME
-
功能:将已创建的容器连接到指定的Docker网络中。
-
选项:无特定选项,但可以使用
--alias
为容器在网络中设置别名。 -
示例:
docker network connect my_network my_container
4.5 断开容器与网络的连接
-
命令:
docker network disconnect [OPTIONS] NETWORK_NAME CONTAINER_NAME
-
功能:断开指定容器与指定Docker网络的连接。
-
选项:无特定选项。
-
示例:
docker network disconnect my_network my_container
4.6 删除网络
-
命令:
docker network rm [OPTIONS] NETWORK_NAME
-
功能:删除指定的Docker网络。
-
选项:无特定选项,但可以同时删除多个网络,如
docker network rm network1 network2
。 -
示例:
docker network rm my_network
4.7 其他注意事项
- 网络类型:Docker支持多种网络类型,包括bridge(桥接网络,默认类型)、host(主机网络)、overlay(覆盖网络,用于多主机集群)等。
- 网络隔离:通过创建不同的网络,可以实现容器之间的隔离,提高安全性。
- 容器间通信:容器可以通过自定义网络在不同主机上安全地相互通信。
综上所述,Docker网络命令提供了强大的网络管理功能,允许用户创建、配置和管理Docker容器之间的网络连接。通过使用这些命令,用户可以实现容器之间的隔离、通信和网络配置,满足各种复杂的网络需求。
5 ElasticsearchTemplate 和 RestHighLevelClient
ElasticsearchTemplate 和 RestHighLevelClient 都是用于与 Elasticsearch 进行交互的客户端工具,但它们在实现方式、使用场景和功能特点上有所不同。以下是对两者的详细介绍以及它们之间的区别:
5.1 ElasticsearchTemplate
-
概述:
ElasticsearchTemplate 是 Spring Data Elasticsearch 提供的一个高级抽象,它封装了底层的 Elasticsearch 客户端操作,使得开发者可以更方便地与 Elasticsearch 进行交互。 -
特点:
- 简化操作:通过提供一系列的方法,如索引、查询、删除等,简化了与 Elasticsearch 的交互过程。
- 丰富的操作方法:支持各种 CRUD 操作,以及复杂的查询和聚合操作。
- 自定义查询:允许开发者通过 Java 代码构建自定义的查询条件,满足更复杂的业务需求。
-
使用场景:
- 适用于使用 Spring 框架的开发者,特别是那些希望利用 Spring Data Elasticsearch 提供的便利性和丰富功能的开发者。
5.2 RestHighLevelClient
-
概述:
RestHighLevelClient 是 Elasticsearch 官方提供的一个高级 REST 客户端,它基于 HTTP 协议与 Elasticsearch 进行交互。与低级的 REST 客户端相比,RestHighLevelClient 提供了更高的抽象层次和更丰富的功能。 -
特点:
- 官方支持:由 Elasticsearch 官方提供,与 Elasticsearch 的兼容性更好。
- 丰富的 API:提供了包括索引管理、数据管理、查询等在内的丰富 API。
- 高性能:通过优化 HTTP 请求和响应的处理,提高了与 Elasticsearch 交互的性能。
-
功能:
- 索引管理:支持创建、删除、判断索引是否存在等操作。
- 数据管理:支持写入、批量写入、更新等操作。
- 查询功能:支持基本查询、复合查询、聚合查询等,可以结合原生 Elasticsearch 查询语法实现更复杂的查询需求。
-
使用场景:
- 适用于需要在 Java 应用程序中集成 Elasticsearch 的开发者,特别是那些希望使用 Elasticsearch 官方提供的高级 REST 客户端的开发者。
5.3 两者区别
-
实现方式:
- ElasticsearchTemplate 是基于 Spring Data Elasticsearch 的,它封装了底层的 Elasticsearch 客户端操作,提供了更高层次的抽象。
- RestHighLevelClient 是 Elasticsearch 官方提供的 REST 客户端,它基于 HTTP 协议与 Elasticsearch 进行交互,提供了更丰富的 API 和更高的性能。
-
使用场景:
- ElasticsearchTemplate 更适用于使用 Spring 框架的开发者,特别是那些希望利用 Spring Data Elasticsearch 的便利性和丰富功能的开发者。
- RestHighLevelClient 则更适用于需要在 Java 应用程序中集成 Elasticsearch 的开发者,特别是那些希望使用 Elasticsearch 官方提供的高级 REST 客户端的开发者。
-
功能特点:
- ElasticsearchTemplate 提供了丰富的操作方法,但相对来说,它的抽象层次更高,可能对于某些复杂的查询需求需要开发者进行更多的自定义封装。
- RestHighLevelClient 则提供了更丰富的 API 和更高的性能,对于复杂的查询需求,它可以更好地结合原生 Elasticsearch 查询语法来实现。
综上所述,ElasticsearchTemplate 和 RestHighLevelClient 都是用于与 Elasticsearch 进行交互的重要工具,但它们在实现方式、使用场景和功能特点上有所不同。开发者在选择时,应根据自己的技术栈、业务需求以及对 Elasticsearch 的熟悉程度来做出决策。
相关文章:

Java学习笔记(二十三)
1 CacheEvict CacheEvict是Spring框架中用于清空缓存的注解。以下是对CacheEvict注解的详细介绍: 1.1 作用 CacheEvict注解的主要作用是删除缓存中的数据。在方法执行后或执行前(根据配置),它可以清空指定的缓存项或整个缓存区…...

《AI赋能鸿蒙Next,开启智能关卡设计新时代》
在游戏开发领域,关卡设计是至关重要的一环,它直接影响着玩家的游戏体验和沉浸感。而随着人工智能技术的飞速发展,结合鸿蒙Next系统的强大功能,为游戏的智能关卡设计带来了全新的思路和方法。 利用AI学习玩家行为模式 在鸿蒙Next…...

js:正则表达式
目录 正则表达式的语法 定义 检测 检索 元字符 边界符 量词 字符类 表单判断案例 修饰符 过滤敏感词 正则表达式是一种用于匹配和操作文本的强大工具,它是由一系列字符和特殊字符组成的模式,用于描述要匹配的文本字符组合模式 正则表达式是一…...

linux环境使用docker部署多个war项目
如果你的需求是在一个服务器上部署多个Tomcat项目,并且每个项目需要独立运行,可以通过以下方式实现: 1. 使用不同的端口 每个Tomcat项目可以使用不同的端口号(如9090、9091、9092等),并通过Docker容器分别…...

【react】使用antd Table渲染数据遇到的报错问题
记录自己在开发过程中遇到的报错问题: 目录 原本写法:错误分析:解决方案: 原本写法: render: (text) > {console.log(text, "111111text");console.log(typeof text, "111111text");return t…...

JVM之垃圾回收器G1概述的详细解析
G1(并发) G1 特点 G1(Garbage-First)是一款面向服务端应用的垃圾收集器,应用于新生代和老年代、采用标记-整理算法、软实时、低延迟、可设定目标(最大 STW 停顿时间)的垃圾回收器,用于代替 CMS࿰…...

1.15寒假作业
web:nss靶场ez_ez_php 打开环境,理解代码 使用个体传参的方法,首先代码会检查file参数的前三个字符是不是php,如果是就输出nice,然后用include函数包含file,绕过不是则输出hacker,如果没有file…...

RK356x bsp 5 - 海华AW-CM358SM Wi-Fi/Bt模组调试记录
文章目录 1、环境介绍2、目标3、海华AW-CM358SM3.1、基本信息3.2、支持SDIO3.03.3、电气特性 4、适配流程步骤5、SDIO控制器适配5.1、sdio dts配置5.2、验证 6、Wi-Fi 适配6.1、wifi dts配置6.2、驱动移植6.2.1、kernel menuconfig6.2.2、传统驱动移植6.2.3、RK SDK WIFI/BT驱动…...

支持Google Analytics快捷添加的CMS:费用与部署形式详解
CMS 的费用和部署形式是选择平台的重要参考因素,不同的业务需求需要不同的解决方案。本文将从费用和部署形式两个角度,详细分析支持 Google Analytics 快捷集成的 CMS 和工具,帮助您更好地了解这些平台的特点。 1. BigCommerce 费用ÿ…...

CSS | 实现三列布局(两边边定宽 中间自适应,自适应成比)
目录 示例1 (中间自适应 示例2(中间自适应 示例3(中间自适应 示例4 (自适应成比 示例5(左中定宽,右边自适应 示例6(中间自适应 示例7(中间自适应 示例8(中间定宽…...

fpga系列 HDL:跨时钟域同步 双触发器同步器
目录 **双触发器同步器(Two-Flip-Flop Synchronizer)示例代码**:双触发器同步器的优缺点优点:缺点:适用场景: 应用实例:同步来自spi_slave的单个使能信号 跨时钟域的设计需要特别小心࿰…...

金融项目实战 05|Python实现接口自动化——登录接口
目录 一、代码实现自动化理论及流程 二、脚本实现的理论和准备工作 1、抽取功能转为自动化用例 2、搭建环境(测试工具) 3、搭建目录结构 三、登录接口脚本实现 1、代码编写 1️⃣api目录 2️⃣script目录 2、断言 3、参数化 1️⃣编写数据存储文件:jso…...

《HTML在网络安全中的多面应用:从防范攻击到安全审查》
Html基础 Html简介 HTML(HyperText Markup Language,超文本标记语言)是用于描述网页内容和结构的标准语言。以下是对HTML的简要介绍: 基本概念 定义: HTML不是一种编程语言,而是一种标记语言。 它使用标…...

Linux网络 | 学习传输层网络协议之UDP(短篇)
前言: 本节内容正式迈入传输层网络协议的知识殿堂, 之前的文章, 我们都是在应用层进行翻来覆去。 比如http就是应用层协议, 只不过使用了tcp的系统调用。 从本节开始, 友友们将会学习传输层两大协议: UDP和…...

iOS - 内存屏障的使用场景
内存屏障的使用是为了解决以下几个关键问题: 1. CPU 乱序执行 // 没有内存屏障时,CPU 可能乱序执行 void example() {// 这两行代码可能被 CPU 重排序a 1; // 操作1flag true; // 操作2 }// 使用内存屏障确保顺序 void safeExample() {a 1;…...

MySQL 8.0 新特性详解与实用示例
MySQL 8.0 新特性详解与实用示例 1. 引言 MySQL 8.0 是 MySQL 版本系列中具有里程碑意义的更新版本,带来了大量新功能和优化,极大地提升了数据库的性能和可用性。本文将深入介绍 MySQL 8.0 的主要新特性及其应用场景,帮助你在项目中更高效地…...

【STM32-学习笔记-5-】ADC
文章目录 ADCADC函数Ⅰ、ADC_InitTypeDef结构体参数①、ADC_Mode②、ADC_DataAlign③、ADC_ExternalTrigConv④、ADC_ContinuousConvMode⑤、ADC_ScanConvMode⑥、ADC_NbrOfChannel Ⅱ、ADC配置示例1、单次转换,非扫描单次转换非扫描模式下,获取多通道的…...

TY1801 反激变换器PWM GaN功率开关
TY1801 是一款针对离线式反激变换器的多模式 PWM GaN 功率开关。TY1801 内置 GaN 功率管,它具备超宽 的 VCC 工作范围,非常适用于 PD 快充等要求宽输出电压的应用场合,系统不需要使用额外的绕组或外围降压电路,节省系统 BOM 成本。TY1801 支持 Burst&…...

Jenkins安装、插件下载及构建环境配置详解
Jenkins简介 1.1 简介 Jenkins 是一个基于Java开发的开源持续集成工具,它提供了一个开放且易用的软件平台,主要用于自动化构建、测试和部署软件项目,以实现持续集成(CI)和持续交付/部署(CD)。…...

ESP32,uart安装驱动uart_driver_install函数剖析,以及intr_alloc_flags 参数的意义
在 uart_driver_install 函数中,参数 RX_BUF_SIZE * 2 指定了接收缓冲区(RX buffer)的大小。这个参数对于 UART 驱动程序来说非常重要,因为它决定了可以存储多少接收到的数据,直到应用程序读取它们为止。下面是对该函数…...

Ubuntu把应用程序放到桌面
有时候我们下载的软件是一个文件夹,通常需要进入进入指定文件夹下去执行.sh 文件来启动,下面来个实例如何把idea放到桌面 打开文件目录/usr/share/applications/或者~/.local/share/applications/目录。第一个目录是全局的,所有用户都可以使…...

什么是端口映射
端口映射 端口映射(Port Mapping)是一种网络技术,用于将外部网络请求转发到内部网络的特定设备或服务。它通常用于以下场景: 外部访问内部服务:允许外部用户通过公网IP访问内网中的设备或服务。多设备共享IP…...

数据结构《MapSet哈希表》
文章目录 一、搜索树1.1 定义1.2 模拟实现搜索 二、Map2.1 定义2.2 Map.Entry2.3 TreeMap的使用2.4 Map的常用方法 三、Set3.1 定义3.2 TreeSet的使用3.3 Set的常用方法 四、哈希表4.1 哈希表的概念4.2 冲突4.2.1 冲突的概念4.2.2 冲突的避免1. 选择合适的哈希函数2. 负载因子调…...

【QT】QComboBox:activated信号和currentIndexChanged信号的区别
目录 1、activated1.1 原型1.2 触发机制1.3 使用场景1.4 连接信号和槽的方法1.4.1 方式一1.4.2 方式二 2、currentIndexChanged2.1 原型2.2 触发机制2.3 使用场景2.4 连接信号和槽的方法 1、activated 1.1 原型 [signal] void QComboBox::activated(int index) [signal] void…...

【Block总结】ELGCA模块,池化-转置(PT)注意力和深度卷积有效聚合局部和全局上下文信息
ELGCA结构 论文题目:ELGC-Net: Efficient Local-Global Context Aggregation for Remote Sensing Change Detection 论文链接:https://arxiv.org/pdf/2403.17909 官方github:https://github.com/techmn/elgcnet 高效局部-全局上下文聚合器&…...

MERN全栈脚手架(MongoDB、Express、React、Node)与Yeoman详解
MERN 全栈脚手架是一种用于快速构建基于 MongoDB、Express、React 和 Node.js 的全栈应用的框架或模板。它帮助开发者快速启动项目,减少了从零开始配置的时间。以下是关于 MERN 全栈脚手架的详细解析。 一、MERN 技术栈简介 MongoDB: 文档型数据库,用于…...

基于springboot+vue+微信小程序的宠物领养系统
基于springbootvue微信小程序的宠物领养系统 一、介绍 本项目利用SpringBoot、Vue和微信小程序技术,构建了一个宠物领养系统。 本系统的设计分为两个层面,分别为管理层面与用户层面,也就是管理者与用户,管理权限与用户权限是不…...

如何使用策略模式并让spring管理
1、策略模式公共接口类 BankFileStrategy public interface BankFileStrategy {String getBankFile(String bankType) throws Exception; } 2、策略模式业务实现类 Slf4j Component public class ConcreteStrategy implements BankFileStrategy {Overridepublic String ge…...

react中hooks之useRef 用法总结
1. 基本概念 useRef 是 React 的一个 Hook,返回一个可变的 ref 对象,其 .current 属性被初始化为传入的参数。这个对象在组件的整个生命周期内保持不变。 2. 主要用途和特性 2.1 获取 DOM 元素实例 function TextInputWithFocusButton() {const inpu…...

使用 Docker 部署 Java 项目(通俗易懂)
目录 1、下载与配置 Docker 1.1 docker下载(这里使用的是Ubuntu,Centos命令可能有不同) 1.2 配置 Docker 代理对象 2、打包当前 Java 项目 3、进行编写 DockerFile,并将对应文件传输到 Linux 中 3.1 编写 dockerfile 文件 …...