是时候将javax替换为Jakarta了

2024-04-27 1344阅读

开始

相信很多朋友在使用新版本的Spring的时候,发现了一些叫jakarta的包,看起来有点陌生。

很多时候,比较纠结不知道该导入哪一个包。

jakarta其实就是之前的javax。

主要JavaEE相关的,从之前javax名字也可以看出来,主要是扩展部分,最典型的就是Servlet。

Oracle已经将JavaEE捐献给了Eclipse基金会,从JavaEE 8开始就被正式被改名为jakarta EE

jakarta EE官网

eclipse Jakarta组

javax这个包是Oracle的,涉及商标和版权原因,所以改名也很正常。

新版本的除了包含在JDK包中的除了javax.sql部分的,其他的javax部分基本都会替换为jakarta。

是时候将javax替换为Jakarta了

    jakarta.servlet
    jakarta.servlet-api
    6.1.0-M1
    provided

javax.servlet在2018年之后就没有更新了,因为2018年Oracle把JavaEE捐赠给Eclipse基金会之后项目就迁移了。

    javax.servlet
    javax.servlet-api
    4.0.1
    provided

新版本的Spring已经使用的是Jakarta了:

是时候将javax替换为Jakarta了

Druid也添加了相应的支持:

是时候将javax替换为Jakarta了

下面我们就以Druid为例,来看一看。

Druid starter方式

可以使用druid的starter

    com.alibaba
    druid-spring-boot-starter
    1.2.20

spring.datasource.initial-size=5
spring.datasource.min-idle=5
spring.datasource.max-active=25
spring.datasource.max-wait=1000
spring.datasource.time-between-eviction-runs-millis=60000
spring.datasource.validation-query=SELECT 1 as nums
spring.datasource.test-while-idle=true
spring.datasource.test-on-borrow=false
spring.datasource.test-on-return=false
spring.datasource.pool-prepared-statements=true
spring.datasource.max-pool-prepared-statement-per-connection-size=20
spring.datasource.druid.filters=stat,wall,slf4j
spring.druid.stat-view-servlet.enabled=true
spring.druid.stat-view-servlet.url-pattern=/druid/*
spring.druid.stat-view-servlet.login-username=tim
spring.druid.stat-view-servlet.login-password=123456
spring.druid.web-stat-filter.enabled=true
spring.druid.web-stat-filter.url-pattern=/*
spring.druid.web-stat-filter.exclusions='*.js,*.gif,*.jpg,*.png,*.css,*.ico,/druid/*'
spring.druid.filter.stat.slow-sql-millis=1000
spring.druid.filter.stat.log-slow-sql=true
spring.druid.filter.stat.enabled=true
spring.druid.filter.wall.enabled=true
spring.druid.filter.wall.config.drop-table-allow=false
spring.druid.filter.wall.config.select-all-column-allow=false

自定义Config

也可以直接使用druid

    com.alibaba
    druid
    1.2.20

import com.alibaba.druid.pool.DruidDataSource;
import com.alibaba.druid.support.jakarta.StatViewServlet;
import com.alibaba.druid.support.jakarta.WebStatFilter;
import lombok.extern.slf4j.Slf4j;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.boot.web.servlet.FilterRegistrationBean;
import org.springframework.boot.web.servlet.ServletRegistrationBean;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import javax.sql.DataSource;
import java.sql.SQLException;
import java.util.List;
@Configuration
@Slf4j
public class DruidDataSourceConfig {
    @ConfigurationProperties(prefix = "spring.datasource")
    @Bean
    public DataSource dataSource() {
        DruidDataSource druidDataSource = new DruidDataSource();
        try {
            druidDataSource.setFilters("stat,wall");
        } catch (SQLException e) {
            log.error(e.getMessage(),e);
        }
        return druidDataSource;
    }
    @Bean
    public ServletRegistrationBean statViewServlet() {
        StatViewServlet statViewServlet = new StatViewServlet();
        ServletRegistrationBean servletRegistrationBean =
                new ServletRegistrationBean(statViewServlet, "/druid/*");
        servletRegistrationBean.addInitParameter("loginUsername", "druid");
        servletRegistrationBean.addInitParameter("loginPassword", "123456");
        return servletRegistrationBean;
    }
    @Bean
    public FilterRegistrationBean webStatFilter() {
        WebStatFilter webStatFilter = new WebStatFilter();
        FilterRegistrationBean filterRegistrationBean =
                new FilterRegistrationBean(webStatFilter);
        // 设置统计的Web URL
        filterRegistrationBean.setUrlPatterns(List.of("/*"));
        // 设置排除的Web URL
        filterRegistrationBean.addInitParameter("exclusions", "*.js,*.gif,*.jpg,*.png,*.css,*.ico,/druid/*");
        return filterRegistrationBean;
    }
}

druid github

VPS购买请点击我

免责声明:我们致力于保护作者版权,注重分享,被刊用文章因无法核实真实出处,未能及时与作者取得联系,或有版权异议的,请联系管理员,我们会立即处理! 部分文章是来自自研大数据AI进行生成,内容摘自(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供学习参考,不准确地方联系删除处理! 图片声明:本站部分配图来自人工智能系统AI生成,觅知网授权图片,PxHere摄影无版权图库和百度,360,搜狗等多加搜索引擎自动关键词搜索配图,如有侵权的图片,请第一时间联系我们,邮箱:ciyunidc@ciyunshuju.com。本站只作为美观性配图使用,无任何非法侵犯第三方意图,一切解释权归图片著作权方,本站不承担任何责任。如有恶意碰瓷者,必当奉陪到底严惩不贷!

目录[+]