jdk21 升级 - javax -> jakarta

常见需要替换升级模块

1. Servlet API (javax.servlet → jakarta.servlet)

背景:Servlet API 是Java Web应用的核心,用于处理HTTP请求和响应。随着Java EE向Jakarta EE的迁移,javax.servlet 包名被替换为 jakarta.servlet。
操作建议:
如果你的应用使用Spring Boot,并且依赖于Tomcat、Jetty或Undertow作为Servlet容器,需要将依赖从javax.servlet-api迁移到jakarta.servlet-api。
确保使用jakarta.servlet-api版本5.0或更高版本。

<dependency>
    <groupId>jakarta.servlet</groupId>
    <artifactId>jakarta.servlet-api</artifactId>
    <version>5.0.0</version>
    <scope>provided</scope>
</dependency>

2. JPA / Hibernate (javax.persistence → jakarta.persistence)

背景:JPA(Java Persistence API)是Java EE中用于对象关系映射的标准API,而Hibernate是其最流行的实现之一。随着迁移,javax.persistence 包名被替换为 jakarta.persistence。
操作建议:
如果你的应用使用JPA(Hibernate),需要升级到Hibernate 6+,因为这是第一个支持jakarta.persistence的版本。
替换代码中所有javax.persistence.注解为jakarta.persistence.

<dependency>
    <groupId>org.hibernate</groupId>
    <artifactId>hibernate-core</artifactId>
    <version>6.0.0</version>
</dependency>

3. JAX-RS / REST (javax.ws.rs → jakarta.ws.rs)

背景:JAX-RS(Java API for RESTful Web Services)是Java EE中用于构建RESTful Web服务的标准API。随着迁移,javax.ws.rs 包名被替换为 jakarta.ws.rs。
操作建议:
如果你的应用使用RESTEasy、Jersey或其他JAX-RS实现,需要切换到jakarta.ws.rs-api依赖。

<dependency>
    <groupId>jakarta.ws.rs</groupId>
    <artifactId>jakarta.ws.rs-api</artifactId>
    <version>3.0.0</version>
</dependency>

4. JSP / JSF (javax.faces, javax.servlet.jsp → jakarta.faces, jakarta.servlet.jsp)

背景:JSP(JavaServer Pages)和JSF(JavaServer Faces)是Java EE中用于构建Web界面的技术。随着迁移,相关包名也发生了变化。
操作建议:
如果你的应用使用JSP或JSF,需要升级相关依赖。

<dependency>
    <groupId>jakarta.faces</groupId>
    <artifactId>jakarta.faces-api</artifactId>
    <version>3.0.0</version>
</dependency>

5. Bean Validation (javax.validation → jakarta.validation)

背景:Bean Validation是Java EE中用于验证JavaBean的标准API。随着迁移,javax.validation 包名被替换为 jakarta.validation。
操作建议:
如果你的应用使用Hibernate Validator,需要切换到支持jakarta.validation的版本。

<dependency>
    <groupId>org.hibernate.validator</groupId>
    <artifactId>hibernate-validator</artifactId>
    <version>8.0.0</version>
</dependency>

6. JMS (javax.jms → jakarta.jms)

背景:JMS(Java Message Service)是Java EE中用于消息传递的标准API。随着迁移,javax.jms 包名被替换为 jakarta.jms。
操作建议:
如果你的应用使用ActiveMQ或其他消息提供者,需要确保它们支持jakarta.jms。

<dependency>
    <groupId>jakarta.jms</groupId>
    <artifactId>jakarta.jms-api</artifactId>
    <version>3.0.0</version>
</dependency>

7. Mail (javax.mail → jakarta.mail)

背景:JavaMail是Java EE中用于发送和接收电子邮件的API。随着迁移,javax.mail 包名被替换为 jakarta.mail。
操作建议:
如果你的应用使用JavaMail,需要切换到jakarta.mail。

<dependency>
    <groupId>com.sun.mail</groupId>
    <artifactId>jakarta.mail</artifactId>
    <version>2.0.0</version>
</dependency>

其他部分

XML JAXB

XML JAXB(Java Architecture for XML Binding)是 Java 平台中的一个框架,用于将 Java 对象与 XML 数据之间进行转换。它是 Java 的标准 API

旧版本

JAXBContext context = JAXBContext.newInstance(objectType);
Marshaller marshaller = context.createMarshaller();
marshaller.setProperty(Marshaller.JAXB_FORMATTED_OUTPUT, true);
marshaller.setProperty(Marshaller.JAXB_ENCODING, charset);
ByteArrayOutputStream bos = new ByteArrayOutputStream();
XMLSerializer serial = new XMLSerializer();
serial.setOutputByteStream(bos);
marshaller.marshal(xmlObject, serial.asContentHandler());
return bos.toString();

新版本

pom.xml 依赖

<!-- JAXB API -->
        <dependency>
            <groupId>jakarta.xml.bind</groupId>
            <artifactId>jakarta.xml.bind-api</artifactId>
        </dependency>
        <!-- JAXB 实现 -->
        <dependency>
            <groupId>org.glassfish.jaxb</groupId>
            <artifactId>jaxb-runtime</artifactId>
        </dependency>

转换对象


public class MarshallerUtil {

    public static <T> String toXmlString(T object) throws Exception {
        // Create a JAXB context for the root class
        JAXBContext context = JAXBContext.newInstance(ContentRoot.class);

        // Create a marshaller
        Marshaller marshaller = context.createMarshaller();
        marshaller.setProperty(Marshaller.JAXB_FORMATTED_OUTPUT, true);

        // Serialize Java object to XML
        StringWriter writer = new StringWriter();
        marshaller.marshal(object, writer);
        return writer.toString();
    }

    public static <T> T toJAXB(Class<T> clazz, String xml) throws Exception {
        // Create a JAXB context for the root class
        JAXBContext context = JAXBContext.newInstance(clazz);

        // Create an unmarshaller
        Unmarshaller unmarshaller = context.createUnmarshaller();

        // Deserialize XML to Java object
        return (T) unmarshaller.unmarshal(new StringReader(xml));
    }
}

工具

Apache Tomcat Jakarta EE迁移工具

Apache Tomcat Jakarta EE迁移工具是一个强大的开源工具,专门用于将基于Java EE 8的应用程序迁移到Jakarta EE 9。它能够自动将javax.*命名空间中的包和类迁移到jakarta.*命名空间

GitCode - tomcat-jakartaee-migration

java -jar jakartaee-migration-*.jar <source> <destination>
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容