使用 IDEA + Maven 搭建传统 Spring MVC 项目的详细步骤(非Spring Boot)

搭建Spring MVC项目

以下是一个使用 IDEA + Maven 搭建传统 Spring MVC 项目的详细步骤(非Spring Boot),包含完整示例代码:


第一步:创建Maven项目

  1. 打开IDEA -> New Project
  2. 选择 Maven -> 勾选 Create from archetype -> 选择 maven-archetype-webapp
  3. 填写 GroupIdArtifactId(如:com.example / springmvc-demo)

第二步:配置pom.xml

xml 复制代码
<project>
    <modelVersion>4.0.0</modelVersion>
    <groupId>com.example</groupId>
    <artifactId>springmvc-demo</artifactId>
    <version>1.0-SNAPSHOT</version>
    <packaging>war</packaging>

    <dependencies>
        <!-- Spring MVC -->
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-webmvc</artifactId>
            <version>5.3.29</version>
        </dependency>
        
        <!-- Servlet API -->
        <dependency>
            <groupId>javax.servlet</groupId>
            <artifactId>javax.servlet-api</artifactId>
            <version>4.0.1</version>
            <scope>provided</scope>
        </dependency>
        
        <!-- JSP支持 -->
        <dependency>
            <groupId>javax.servlet.jsp</groupId>
            <artifactId>javax.servlet.jsp-api</artifactId>
            <version>2.3.3</version>
            <scope>provided</scope>
        </dependency>
        
        <!-- JSTL -->
        <dependency>
            <groupId>javax.servlet</groupId>
            <artifactId>jstl</artifactId>
            <version>1.2</version>
        </dependency>
    </dependencies>

    <build>
        <plugins>
            <!-- 配置Maven编译插件 -->
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-compiler-plugin</artifactId>
                <version>3.8.1</version>
                <configuration>
                    <source>1.8</source>
                    <target>1.8</target>
                </configuration>
            </plugin>
        </plugins>
    </build>
</project>

第三步:配置web.xml

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

xml 复制代码
<?xml version="1.0" encoding="UTF-8"?>
<web-app version="4.0" 
         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">

    <!-- 配置DispatcherServlet -->
    <servlet>
        <servlet-name>dispatcher</servlet-name>
        <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
        <init-param>
            <param-name>contextConfigLocation</param-name>
            <param-value>/WEB-INF/spring-mvc.xml</param-value>
        </init-param>
        <load-on-startup>1</load-on-startup>
    </servlet>

    <!-- 映射所有请求到DispatcherServlet -->
    <servlet-mapping>
        <servlet-name>dispatcher</servlet-name>
        <url-pattern>/</url-pattern>
    </servlet-mapping>
</web-app>

第四步:创建Spring配置文件

src/main/webapp/WEB-INF/spring-mvc.xml

xml 复制代码
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xmlns:context="http://www.springframework.org/schema/context"
       xmlns:mvc="http://www.springframework.org/schema/mvc"
       xsi:schemaLocation="http://www.springframework.org/schema/beans
        http://www.springframework.org/schema/beans/spring-beans.xsd
        http://www.springframework.org/schema/context
        http://www.springframework.org/schema/context/spring-context.xsd
        http://www.springframework.org/schema/mvc
        http://www.springframework.org/schema/mvc/spring-mvc.xsd">

    <!-- 开启注解扫描 -->
    <context:component-scan base-package="com.example.controller"/>
    
    <!-- 开启MVC注解驱动 -->
    <mvc:annotation-driven/>
    
    <!-- 视图解析器 -->
    <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
        <property name="prefix" value="/WEB-INF/views/"/>
        <property name="suffix" value=".jsp"/>
    </bean>
</beans>

第五步:创建控制器

src/main/java/com/example/controller/HelloController.java

java 复制代码
package com.example.controller;

import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.GetMapping;

@Controller
public class HelloController {

    @GetMapping("/hello")
    public String sayHello(Model model) {
        model.addAttribute("message", "这是我的第一个Spring MVC程序!");
        return "hello"; // 对应/WEB-INF/views/hello.jsp
    }
}

第六步:创建JSP视图

src/main/webapp/WEB-INF/views/hello.jsp

jsp 复制代码
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>欢迎页面</title>
</head>
<body>
    <h1>${message}</h1>
</body>
</html>

第七步:配置Tomcat并运行

  1. 点击IDEA右上角 Add Configuration -> + -> Tomcat Server -> Local

Name:自定义配置名称(如 tomcat)

Application Server:选择已配置的 Tomcat

URL:访问路径可以是http://localhost:8080/项目名/,这里没有配置项目名

JRE:这里采用系统配置好的,如果没有配置的,这里配置下

HTTP Port:默认 8080(按需修改)

  1. Deployment 标签页添加项目war包

切换到 Deployment 标签 → 点击 + → Artifact → 选择步骤 2 生成的 Exploded Artifact

Application Context:设置上下文路径(如 /myapp,默认可能为 Artifact 名)

启动项目:

1、点击 Run/Debug Configurations 下拉框 → 选择配置好的 Tomcat 配置。

2、点击 Run(绿色三角)或 Debug(虫子图标)。

3、控制台输出 Tomcat started on port(s): 8080 表示成功。

4、访问 http://localhost:8080/你的上下文路径 测试。


目录结构

复制代码
src
├── main
│   ├── java
│   │   └── com
│   │       └── example
│   │           └── controller
│   │               └── HelloController.java
│   ├── resources
│   └── webapp
│       ├── WEB-INF
│       │   ├── spring-mvc.xml
│       │   ├── views
│       │   │   └── hello.jsp
│       │   └── web.xml
│       └── index.jsp

常见问题解决

  1. 404错误

    • 检查视图路径是否匹配:return "hello" 对应 /WEB-INF/views/hello.jsp
    • 确保URL路径正确:http://localhost:8080/[项目名]/hello
  2. No mapping found for HTTP request

    • 检查@Controller注解是否被扫描到(确认component-scan包路径正确)
  3. JSP无法解析EL表达式

    • 在JSP头部添加:<%@ page isELIgnored="false" %>

与传统Spring Boot对比

配置项 传统Spring MVC Spring Boot
项目创建 手动配置web.xml和Spring配置 自动配置
内嵌服务器 需要外置Tomcat 内置Tomcat/Jetty
依赖管理 需手动指定版本 starter依赖自动版本管理
部署方式 打包war部署到服务器 可打包jar独立运行
相关推荐
liaokailin12 分钟前
Spring AI 实战:第九章、Spring AI MCP之万站直通
java·人工智能·spring
新生农民2 小时前
一小时算法
spring
fanTuanye3 小时前
SpringMVC详解
java·spring·mvc
Alsn864 小时前
10.idea中创建springboot项目_jdk17
java·spring boot·intellij-idea
程序员buddha4 小时前
【Spring】idea + maven 从零创建Spring IoC容器示例
spring·maven·intellij-idea
magic 2455 小时前
Spring 基于 XML 的自动装配:原理与实战详解
xml·java·spring
帮帮志6 小时前
idea创建springboot工程-指定阿里云地址创建工程报错
spring boot·阿里云·intellij-idea
heart000_16 小时前
如何在IDEA中去除警告波浪线
java·ide·intellij-idea
奔驰的小野码8 小时前
SpringAI实现AI应用-搭建知识库
java·人工智能·spring boot·后端·spring·知识图谱