news 2026/4/22 20:13:30

Spring、Spring MVC、SpringBoot的欢迎页配置

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Spring、Spring MVC、SpringBoot的欢迎页配置

一、Spring MVC(纯 XML 配置 / 注解配置)

1. XML 配置(传统方式)

适用于基于spring-mvc.xml配置的项目,核心是配置WelcomePageHandlerMappingmvc:view-controller

  • path="/"表示访问项目根路径(如http://localhost:8080/项目名/)时触发;

  • view-name="index"会结合视图解析器的前缀 / 后缀,最终指向/WEB-INF/pages/index.jsp

  • 如果页面放在 webapp 根目录(而非 WEB-INF),可直接配置<mvc:view-controller path="/" view-name="/index.jsp"/>

<!-- 1. 基础配置:开启注解驱动、视图解析器(示例为JSP视图) --> <mvc:annotation-driven /> <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver"> <property name="prefix" value="/WEB-INF/pages/" /> <!-- 页面前缀 --> <property name="suffix" value=".jsp" /> <!-- 页面后缀 --> </bean> <!-- 2. 配置欢迎页:访问根路径/时,跳转到index.jsp --> <!-- 方式A:直接配置视图控制器(推荐) --> <mvc:view-controller path="/" view-name="index"/> <!-- 方式B:配置WelcomePageHandlerMapping(兼容老版本) --> <!-- <bean class="org.springframework.web.servlet.handler.WelcomePageHandlerMapping"> <property name="welcomePage" value="/WEB-INF/pages/index.jsp"/> </bean> -->

2. 注解配置(无 XML)

适用于基于@Configuration的 Spring MVC 配置,通过编程式配置视图控制器

import org.springframework.context.annotation.Configuration; import org.springframework.web.servlet.config.annotation.EnableWebMvc; import org.springframework.web.servlet.config.annotation.ViewControllerRegistry; import org.springframework.web.servlet.config.annotation.WebMvcConfigurer; @Configuration @EnableWebMvc // 开启Spring MVC注解支持 public class WebMvcConfig implements WebMvcConfigurer { // 配置欢迎页 @Override public void addViewControllers(ViewControllerRegistry registry) { // 访问/时,跳转到index视图(结合视图解析器) registry.addViewController("/").setViewName("index"); // 如果是静态页面(如webapp下的index.html),直接指定路径: // registry.addViewController("/").setViewName("/index.html"); } // 配置视图解析器(可选,根据页面类型) /* @Bean public InternalResourceViewResolver viewResolver() { InternalResourceViewResolver resolver = new InternalResourceViewResolver(); resolver.setPrefix("/WEB-INF/pages/"); resolver.setSuffix(".jsp"); return resolver; } */ }

二、Spring 框架

纯 Spring 框架(非 Web 场景)没有 “欢迎页” 概念,因为 Spring 核心是 IoC/DI 容器,不处理 Web 请求;只有当 Spring 结合 Spring MVC 用于 Web 开发时,才需要按上面 Spring MVC 的方式配置欢迎页。

如果是 Spring 整合 Web 但未用 Spring MVC(极少场景),本质还是依赖 Servlet 规范配置欢迎页:在web.xml中配置

<!-- web.xml 中配置Servlet规范的欢迎页 --> <welcome-file-list> <welcome-file>index.html</welcome-file> <welcome-file>index.jsp</welcome-file> </welcome-file-list>

三、SpringBoot(最简化配置)

1. 静态资源欢迎页

SpringBoot 会自动扫描以下目录下的index.html/index.jsp作为欢迎页

2. 自定义控制器指定欢迎页

如果需要动态逻辑(比如登录判断后跳转),可通过@Controller配置

import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.GetMapping; @Controller public class IndexController { // 访问根路径时跳转 @GetMapping("/") public String index() { // 可添加自定义逻辑(如用户登录状态判断) // 返回的"index"会结合视图解析器(如Thymeleaf/JSP)找页面 return "index"; // 如果是静态页面,直接返回路径:return "/index.html"; } }

3. 配置文件指定(覆盖默认)

如果需要自定义欢迎页路径,可在application.properties/application.yml中配置

# application.properties # 方式1:通过视图控制器指定 spring.mvc.view.controller.path=/ spring.mvc.view.controller.view-name=custom-index # 对应templates/custom-index.html(Thymeleaf) # 方式2:如果是JSP,需先配置视图解析器 spring.mvc.view.prefix=/WEB-INF/jsp/ spring.mvc.view.suffix=.jsp spring.mvc.view.controller.path=/ spring.mvc.view.controller.view-name=index # 对应/WEB-INF/jsp/index.jsp

注意:SpringBoot 对 JSP 支持较弱

若用 JSP 做欢迎页,需要:

(1)添加 JSP 依赖:按方式 2/3 配置,而非方式 1(静态资源目录不识别 JSP

<dependency> <groupId>org.apache.tomcat.embed</groupId> <artifactId>tomcat-embed-jasper</artifactId> <scope>provided</scope> </dependency> <dependency> <groupId>javax.servlet</groupId> <artifactId>jstl</artifactId> </dependency>

(2)JSP 文件需放在src/main/webapp/WEB-INF/jsp/下(不能放在 resources 下)

(3)按方式 2/3 配置,而非方式 1(静态资源目录不识别 JSP)

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/17 8:07:51

【课程设计/毕业设计】基于springboot的华强北二手手机商城管理系统基于springboot的二手手机销售系统【附源码、数据库、万字文档】

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

作者头像 李华
网站建设 2026/4/19 22:21:36

为什么建议使用Turnitin系统查重时不要提交PDF格式文件?

英文论文查重一般使用Turnitin系统。 Turnitin检测系统&#xff1a;https://students-turnai.similarity-check.com/ 进入检测网站&#xff0c;我们实际上可以看到&#xff0c;如果提交文件检测&#xff0c;实际上Turnitin系统查英文论文重复率是支持PDF格式上传进行查重的。…

作者头像 李华
网站建设 2026/4/18 6:40:31

WebCode 与 Clawdbot 项目深度对比分析

&#x1f4ca; 执行摘要项目WebCodeClawdbot定位在线 AI 全能工作平台&#xff08;Web&#xff09;个人 AI 助手框架&#xff08;CLI/Gateway&#xff09;核心技术.NET 10.0 Blazor ServerNode.js 22 TypeScript架构风格分层架构 DDDGateway-Channel-Agent 三层架构主要功能…

作者头像 李华
网站建设 2026/4/18 16:53:30

揭秘!AI应用架构师眼中的智能Web3应用开发框架精髓

揭秘!AI应用架构师眼中的智能Web3应用开发框架精髓 关键词:智能Web3应用, AI与区块链融合, 去中心化AI架构, 智能合约开发, Web3开发框架, AI模型链上集成, 去中心化应用(DApp)设计 摘要:当人工智能(AI)的"智慧大脑"遇上Web3的"去中心化灵魂",会碰撞出…

作者头像 李华