使用 IDEA + Maven 搭建传统 Spring MVC 项目的详细步骤(非Spring Boot)
搭建Spring MVC项目
- 第一步:创建Maven项目
- 第二步:配置pom.xml
- 第三步:配置web.xml
- 第四步:创建Spring配置文件
- 第五步:创建控制器
- 第六步:创建JSP视图
- 第七步:配置Tomcat并运行
- 目录结构
- 常见问题解决
- 与传统Spring Boot对比
以下是一个使用 IDEA + Maven 搭建传统 Spring MVC 项目的详细步骤(非Spring Boot),包含完整示例代码:
第一步:创建Maven项目
- 打开IDEA ->
New Project
- 选择
Maven
-> 勾选Create from archetype
-> 选择maven-archetype-webapp
- 填写
GroupId
和ArtifactId
(如:com.example / springmvc-demo)
第二步:配置pom.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 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 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/beanshttp://www.springframework.org/schema/beans/spring-beans.xsdhttp://www.springframework.org/schema/contexthttp://www.springframework.org/schema/context/spring-context.xsdhttp://www.springframework.org/schema/mvchttp://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
:
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
:
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head><title>欢迎页面</title>
</head>
<body><h1>${message}</h1>
</body>
</html>
第七步:配置Tomcat并运行
- 点击IDEA右上角
Add Configuration
->+
->Tomcat Server
->Local
Name:自定义配置名称(如 tomcat)
Application Server:选择已配置的 Tomcat
URL:访问路径可以是http://localhost:8080/项目名/,这里没有配置项目名
JRE:这里采用系统配置好的,如果没有配置的,这里配置下
HTTP Port:默认 8080(按需修改)
2. 在 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
常见问题解决
-
404错误:
- 检查视图路径是否匹配:
return "hello"
对应/WEB-INF/views/hello.jsp
- 确保URL路径正确:
http://localhost:8080/[项目名]/hello
- 检查视图路径是否匹配:
-
No mapping found for HTTP request:
- 检查
@Controller
注解是否被扫描到(确认component-scan
包路径正确)
- 检查
-
JSP无法解析EL表达式:
- 在JSP头部添加:
<%@ page isELIgnored="false" %>
- 在JSP头部添加:
与传统Spring Boot对比
配置项 | 传统Spring MVC | Spring Boot |
---|---|---|
项目创建 | 手动配置web.xml和Spring配置 | 自动配置 |
内嵌服务器 | 需要外置Tomcat | 内置Tomcat/Jetty |
依赖管理 | 需手动指定版本 | starter依赖自动版本管理 |
部署方式 | 打包war部署到服务器 | 可打包jar独立运行 |