springboot3.1到springboot3.2升级

springboot3.1 -> springboot3.2

1、通过反射获取参数名称

Spring Boot 3.2使用的Spring Framework版本不再试图通过解析字节码来推断参数名。 如果遇到依赖注入或属性绑定问题,检查下是否正在使用 -parameters 选项进行编译

public class TestDemo {

    public String say(String message){
        return "hello world:"+message;
    }

    public static void main(String[] args) {
        Method method = ReflectionUtils.findMethod(TestDemo.class,"say",String.class);
        //通过springfromework的反射工具类 获取方法say参数名称
        ParameterNameDiscoverer discoverer = new DefaultParameterNameDiscoverer();
        String[] parameterNames = discoverer.getParameterNames(method);

        Stream.of(discoverer.getParameterNames(method)).forEach(System.out::println);
    }
}

springboot3.2之前的版本可以获取到方法say的参数名message,springboot3.2无法获取到。如果想获取到方法的参数名,如果是maven项目,需要在pom.xml中添加如下插件(不同的maven版本可能配置方式不一样):

    <plugin>
        <groupId>org.apache.maven.plugins</groupId>
        <artifactId>maven-compiler-plugin</artifactId>
        <configuration>
            <compilerArgs>
                <arg>-parameters</arg>
            </compilerArgs>
        </configuration>
    </plugin>

2、自动配置

在 Spring Boot 3.2.2 及以后的版本中,如果你的项目类路径上包含了 spring-security-oauth2-client、spring-security-oauth2-resource-server 或 spring-security-saml2-service-provider 这些依赖,并且没有显式配置 spring.security.user.name 和 spring.security.user.password,那么 Spring Boot 的自动配置将不再尝试提供一个默认的基于用户名和密码的认证机制。

这一变化的原因是为了避免在引入 OAuth 2.0 客户端或资源服务器,或 SAML 2.0 服务提供商等高级安全特性时,产生混淆或冲突。这些高级特性通常有自己的认证和授权机制,因此不再需要或期望有一个基于用户名和密码的默认认证。

在响应式应用中,当类路径上存在 spring-security-oauth2-client 或 spring-security-oauth2-resource-server 时,也会发生类似的自动配置撤销。这是为了确保 OAuth 2.0 相关的配置能够正确地接管安全控制,而不是与基于用户名和密码的默认认证机制发生冲突。

如果你需要配置基于用户名和密码的认证,你需要显式地在你的 application.properties 或 application.yml 文件中进行配置,或者通过编程方式配置 Spring Security。

例如,在 application.properties 中,你可以这样配置:

spring.security.user.name=myuser  
spring.security.user.password=mypassword

3、H2 Version

Spring Boot现在默认使用H2的2.2版本。 要继续使用H2早期版本的数据库, 需要进行数据迁移

4、Oracle UCP数据源

Oracle UCP数据源不再默认设置 validateConnectionOnBorrow 为 true 。 如果沿用旧,可以将 spring.datasource.oracleucp.validate-connection-on-borrow 应用程序属性设置为 true 。

5、OTLP Tracing Endpoint

默认值 management.otlp.tracing.endpoint 已经删除。 OtlpHttpSpanExporter bean现在只有在 management.otlp.tracing.endpoint 有值时才自动配置。 沿用旧配置,需设置 management.otlp.tracing.endpoint=http://localhost:4318/v1/traces 。

6、jetty 12

支持Jetty 12。Jetty 12支持最新的Servlet 6.0 API。在升级过程中,请确保删除任何之前用于覆盖Servlet API版本的配置或依赖项。Jetty 11不再被支持作为嵌入式web服务器

7、RestClient支持

Spring Boot 3.2中的Spring Framework 6.1中引入了RestClient的支持。 这个接口提供了一个函数式的阻塞式HTTP API

8、支持虚拟线程

要使用虚拟线程,需要运行在Java 21上,并将属性 spring.threads.virtual.enabled 设置为 true

(1)Servlet Web服务器

启用虚拟线程后,Tomcat和Jetty将使用虚拟线程进行请求处理。处理web请求的应用程序代码,例如控制器中的方法,将在虚拟线程上运行。

(2)Task Execution

当启用虚拟线程时, applicationTaskExecutor bean将被配置为使用虚拟线程的 SimpleAsyncTaskExecutor 。 任何使用应用程序任务执行器的地方,例如 @EnableAsync 当调用 @Async 方法、Spring MVC的异步请求处理和Spring WebFlux的阻塞执行支持现在都将使用虚拟线程。 和之前一样,任何 TaskDecorator bean都会被应用到自动配置的执行器上,然后应用 spring.task.execution.thread-name-prefix 属性。 其他 spring.task.execution.* 属性会被忽略。

(3)Task Scheduling

当启用虚拟线程时, taskScheduler bean将被配置为使用虚拟线程的 SimpleAsyncTaskScheduler 。 应用了 spring.task.scheduling.thread-name-prefix 属性和 spring.task.scheduling.simple. 属性。 其他 spring.task.scheduling. 属性将被忽略。

(4)保持JVM处于活动状态

配置spring.main.keep-alive=true时,即使所有其他线程都是虚拟(或守护)线程,jvm也将保持活动状态

(5)技术特定的集成

在启用虚拟线程时,将应用以下特定于技术的集成:

RabbitMQ监听器会自动配置一个虚拟线程执行器。

为Kafka监听器自动配置了一个虚拟线程执行器

Spring Data Redis ClusterCommandExecutor 将使用虚拟线程

Apache Pulsar的Spring将使用 VirtualThreadTaskExector 来自动配置 ConcurrentPulsarListenerContainerFactory 和 DefaultPulsarReaderContainerFactory 。

  • 39
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Spring Boot 是一个非常流行的 Java Web 框架,而 MyBatis-Plus 是一个优秀的 ORM 框架,它可以帮助我们更加方便地操作数据库。本篇文章将介绍如何在 Spring Boot 中整合 MyBatis-Plus 3.1。 ## 1. 准备工作 在开始整合之前,我们需要准备好以下环境: - JDK 8+ - Maven 3.2+ - IDE(例如 IntelliJ IDEA 或 Eclipse) ## 2. 创建 Spring Boot 项目 首先,我们需要创建一个 Spring Boot 项目。可以使用 Spring Initializr 来快速创建一个项目。在创建项目的过程中,我们需要选择以下的依赖: - Spring Web - MyBatis-Plus 如果你使用的是 IntelliJ IDEA,可以使用以下方式创建项目: 1. 打开 IntelliJ IDEA,选择 "Create New Project"。 2. 在弹出的对话框中选择 "Spring Initializr"。 3. 配置项目的基本信息,例如 Group、Artifact、Name 等。 4. 在 "Dependencies" 中选择 "Spring Web" 和 "MyBatis-Plus"。 5. 点击 "Next",确认配置信息。 6. 点击 "Finish",完成项目的创建。 如果你使用的是 Eclipse,可以参考以下的步骤: 1. 打开 Eclipse,选择 "File" -> "New" -> "Other"。 2. 在弹出的对话框中选择 "Spring Starter Project"。 3. 配置项目的基本信息,例如 Group、Artifact、Name 等。 4. 在 "Dependencies" 中选择 "Spring Web" 和 "MyBatis-Plus"。 5. 点击 "Finish",完成项目的创建。 ## 3. 配置 MyBatis-Plus 完成项目的创建后,我们需要进行一些配置,以便让 Spring Boot 和 MyBatis-Plus 正常工作。 ### 3.1 配置数据源 首先,我们需要配置数据源。在 Spring Boot 中,我们可以使用以下方式配置数据源: 1. 在 application.properties 或 application.yml 中添加以下配置: ```yaml spring: datasource: url: jdbc:mysql://localhost:3306/test?useSSL=false&useUnicode=true&characterEncoding=utf-8&serverTimezone=Asia/Shanghai username: root password: root driver-class-name: com.mysql.cj.jdbc.Driver ``` 这里我们使用的是 MySQL 数据库,你可以根据自己的实际情况进行修改。 2. 在启动类中添加 @EnableTransactionManagement 注解,开启事务管理: ```java @SpringBootApplication @EnableTransactionManagement public class Application { public static void main(String[] args) { SpringApplication.run(Application.class, args); } } ``` ### 3.2 配置 MyBatis-Plus 接下来,我们需要配置 MyBatis-Plus。在 Spring Boot 中,我们可以使用以下方式配置 MyBatis-Plus: 1. 在 application.properties 或 application.yml 中添加以下配置: ```yaml mybatis-plus: mapper-locations: classpath*:mapper/*.xml type-aliases-package: com.example.demo.entity ``` 这里的 mapper-locations 表示 Mapper 文件的位置,type-aliases-package 表示实体类的包路径。 2. 在启动类中添加 @MapperScan 注解,指定 Mapper 文件的包路径: ```java @SpringBootApplication @EnableTransactionManagement @MapperScan("com.example.demo.mapper") public class Application { public static void main(String[] args) { SpringApplication.run(Application.class, args); } } ``` ### 3.3 配置分页插件 MyBatis-Plus 内置了一个分页插件,可以帮助我们更加方便地进行分页查询。 在 Spring Boot 中,我们可以使用以下方式配置分页插件: 1. 在 application.properties 或 application.yml 中添加以下配置: ```yaml mybatis-plus: configuration: # 分页插件 page-helper: helper-dialect: mysql reasonable: true support-methods-arguments: true params: count=countSql ``` 这里的 helper-dialect 表示数据库类型,reasonable 表示是否启用合理化查询,support-methods-arguments 表示支持多参数查询,params 表示传递给 Mapper 的参数名。 2. 在 Mapper 接口中添加 Page 参数,如下所示: ```java public interface UserMapper extends BaseMapper<User> { List<User> selectUserList(Page<User> page); } ``` ### 3.4 配置自动填充插件 MyBatis-Plus 还内置了一个自动填充插件,可以帮助我们更加方便地进行数据填充。 在 Spring Boot 中,我们可以使用以下方式配置自动填充插件: 1. 在实体类中添加 @TableField 注解,并指定填充策略: ```java @Data public class User { private Long id; private String name; @TableField(fill = FieldFill.INSERT) private Date createTime; @TableField(fill = FieldFill.INSERT_UPDATE) private Date updateTime; } ``` 这里的 fill 表示填充策略,INSERT 表示插入时填充,UPDATE 表示更新时填充。 2. 在 Mapper 接口中添加 @Insert 注解,并指定插入方式: ```java public interface UserMapper extends BaseMapper<User> { @Insert("insert into user(name,create_time,update_time) values(#{name},#{createTime},#{updateTime})") int insertUser(User user); } ``` 这里的 @Insert 注解表示插入数据,#{} 中的属性名与实体类中的属性名一致。 ## 4. 使用 MyBatis-Plus 完成配置后,我们就可以使用 MyBatis-Plus 进行数据库操作了。下面我们来看一些使用示例。 ### 4.1 基本操作 ```java @Service public class UserService { @Autowired private UserMapper userMapper; public User selectById(Long id) { return userMapper.selectById(id); } public List<User> selectList() { return userMapper.selectList(null); } public int insert(User user) { return userMapper.insert(user); } public int updateById(User user) { return userMapper.updateById(user); } public int deleteById(Long id) { return userMapper.deleteById(id); } } ``` 这里的 selectById、selectList、insert、updateById、deleteById 分别表示根据 id 查询、查询列表、插入、更新和删除。 ### 4.2 分页查询 ```java @Service public class UserService { @Autowired private UserMapper userMapper; public List<User> selectUserList(int pageNum, int pageSize) { Page<User> page = new Page<>(pageNum, pageSize); return userMapper.selectUserList(page); } } ``` 这里的 selectUserList 表示分页查询,pageNum 表示页码,pageSize 表示每页大小。Page<User> 表示分页对象。 ### 4.3 自动填充 ```java @RestController public class UserController { @Autowired private UserService userService; @PostMapping("/user") public int insert(User user) { return userService.insert(user); } } ``` 这里的 insert 表示插入数据,当插入数据时,createTime 和 updateTime 会自动填充。 ## 5. 总结 本篇文章介绍了如何在 Spring Boot 中整合 MyBatis-Plus 3.1。首先,我们需要创建一个 Spring Boot 项目,并添加相应的依赖。然后,我们需要进行一些配置,包括数据源、MyBatis-Plus、分页插件和自动填充插件。最后,我们使用 MyBatis-Plus 进行数据库操作。 MyBatis-Plus 是一个非常优秀的 ORM 框架,它可以帮助我们更加方便地操作数据库。如果你想提高自己的开发效率,不妨尝试一下 MyBatis-Plus。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值