Spring 5 WAR项目迁移至javax.servlet | AI生成和翻译

Home 2025.09

你离成功很近了。由于这个项目是 Spring 5(javax.* 时代)且采用 WAR 包,最简洁的方案是:使用 javax.servlet-api 4.x,添加最简化的 web.xml、Java 配置和一个小型控制器。

0) 修复 Servlet API(重要)

Spring 5.2.x 使用 javax.servlet.*,但你的 POM 引入了 jakarta.servlet-api:5.0.0。需替换为 javax

<!-- 将 jakarta 依赖替换为此项 -->
<dependency>
  <groupId>javax.servlet</groupId>
  <artifactId>javax.servlet-api</artifactId>
  <version>4.0.1</version>
  <scope>provided</scope>
</dependency>

(保留 Jetty 9.4 —— 它兼容 Servlet 3.1/4.0 且支持 javax。)

1) web.xml(因你设置了 failOnMissingWebXml=true

创建 src/main/webapp/WEB-INF/web.xml

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee
                             http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd"
         version="4.0">

  <!-- 根 Spring 上下文(后续添加服务层/仓储层时使用) -->
  <listener>
    <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
  </listener>
  <context-param>
    <param-name>contextClass</param-name>
    <param-value>org.springframework.web.context.support.AnnotationConfigWebApplicationContext</param-value>
  </context-param>
  <context-param>
    <param-name>contextConfigLocation</param-name>
    <param-value>com.lzw.config.RootConfig</param-value>
  </context-param>

  <!-- MVC 调度器 Servlet -->
  <servlet>
    <servlet-name>dispatcher</servlet-name>
    <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
    <init-param>
      <param-name>contextClass</param-name>
      <param-value>org.springframework.web.context.support.AnnotationConfigWebApplicationContext</param-value>
    </init-param>
    <init-param>
      <param-name>contextConfigLocation</param-name>
      <param-value>com.lzw.config.WebConfig</param-value>
    </init-param>
    <load-on-startup>1</load-on-startup>
  </servlet>

  <servlet-mapping>
    <servlet-name>dispatcher</servlet-name>
    <url-pattern>/</url-pattern>
  </servlet-mapping>

</web-app>

2) Java 配置

创建两个配置类。

src/main/java/com/lzw/config/RootConfig.java

package com.lzw.config;

import org.springframework.context.annotation.Configuration;

@Configuration
public class RootConfig {
    // 后续若有服务层/仓储层,可在此添加 @Bean 定义
}

src/main/java/com/lzw/config/WebConfig.java

package com.lzw.config;

import org.springframework.context.annotation.ComponentScan;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.EnableWebMvc;

@Configuration
@EnableWebMvc
@ComponentScan(basePackages = "com.lzw.web")
public class WebConfig {
    // 纯 REST 应用可留空。后续如需视图解析/静态资源处理再补充配置
}

3) 示例控制器

src/main/java/com/lzw/web/HelloController.java

package com.lzw.web;

import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;

@RestController
public class HelloController {

    @GetMapping("/hello")
    public String hello() {
        return "Hello, Spring MVC!";
    }
}

4) 目录结构检查

5) 运行项目

由于 POM 中已配置 Jetty:

mvn clean package
mvn jetty:run

访问:http://localhost:8080/hello → 应显示 Hello, Spring MVC!


注意事项与常见问题


Back Donate