原文: http://zetcode.com/spring/defaultservlet/

Spring DefaultServlet教程展示了如何在 Spring 应用中启用默认 servlet。

Spring 是流行的 Java 应用框架。 在本教程中,我们使用 Spring 5 版本。

DefaultServlet

DefaultServlet是大多数 Web 应用的默认资源服务 Servlet,用于提供 HTML 页面和图像等静态资源。

DefaultServletHttpRequestHandler尝试在启动时自动检测容器的默认 Servlet,例如 Tomcat,Jetty,Wildfly 和 Resin。 如果默认 Servlet 是使用其他名称自定义配置的,则必须明确提供默认 Servlet 的名称。

如果我们重写DefaultServlet的路由(/),则可以使用DefaultServletHandlerConfigurerenable()方法启用它,以便我们仍然可以使用容器的默认 Servlet 提供静态资源。

Spring DefaultServlet示例

在以下应用中,我们将 Spring 调度器 servlet 配置为/路径,该路径将重写默认 servlet 的路径。 我们使用DefaultServletHandlerConfigurer启用默认 servlet。

该应用提供一个简单的 HTML 主页,这是一个静态资源。

  1. pom.xml
  2. src
  3. ├───main
  4. ├───java
  5. └───com
  6. └───zetcode
  7. └───config
  8. MyWebInitializer.java
  9. WebConfig.java
  10. ├───resources
  11. logback.xml
  12. └───webapp
  13. index.html
  14. └───test
  15. └───java

这是项目结构。

pom.xml

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <project xmlns="http://maven.apache.org/POM/4.0.0"
  3. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  4. xsi:schemaLocation="http://maven.apache.org/POM/4.0.0
  5. http://maven.apache.org/xsd/maven-4.0.0.xsd">
  6. <modelVersion>4.0.0</modelVersion>
  7. <groupId>com.zetcode</groupId>
  8. <artifactId>defaultservletex</artifactId>
  9. <version>1.0-SNAPSHOT</version>
  10. <packaging>war</packaging>
  11. <properties>
  12. <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
  13. <maven.compiler.source>11</maven.compiler.source>
  14. <maven.compiler.target>11</maven.compiler.target>
  15. </properties>
  16. <dependencies>
  17. <dependency>
  18. <groupId>javax.servlet</groupId>
  19. <artifactId>javax.servlet-api</artifactId>
  20. <version>4.0.1</version>
  21. <scope>provided</scope>
  22. </dependency>
  23. <dependency>
  24. <groupId>ch.qos.logback</groupId>
  25. <artifactId>logback-classic</artifactId>
  26. <version>1.2.3</version>
  27. </dependency>
  28. <dependency>
  29. <groupId>org.springframework</groupId>
  30. <artifactId>spring-webmvc</artifactId>
  31. <version>5.1.3.RELEASE</version>
  32. </dependency>
  33. </dependencies>
  34. <build>
  35. <plugins>
  36. <plugin>
  37. <groupId>org.apache.maven.plugins</groupId>
  38. <artifactId>maven-war-plugin</artifactId>
  39. <version>3.2.2</version>
  40. </plugin>
  41. </plugins>
  42. </build>
  43. </project>

这是 Maven 构建文件。 我们具有以下依赖项:用于 Java Servlet 技术的javax.servlet-api,用于日志记录的logback-classic和用于创建 Spring Web MVC 应用的spring-webmvc

maven-war-plugin创建 Web 存档(WAR)。

com/zetcode/config/MyWebInitializer.java

  1. package com.zetcode.config;
  2. import org.springframework.web.servlet.support.AbstractAnnotationConfigDispatcherServletInitializer;
  3. public class MyWebInitializer extends
  4. AbstractAnnotationConfigDispatcherServletInitializer {
  5. @Override
  6. protected Class<?>[] getRootConfigClasses() {
  7. return null;
  8. }
  9. @Override
  10. protected Class<?>[] getServletConfigClasses() {
  11. return new Class[]{WebConfig.class};
  12. }
  13. @Override
  14. protected String[] getServletMappings() {
  15. return new String[]{"/"};
  16. }
  17. }

MyWebInitializer初始化 Spring Web 应用。

  1. @Override
  2. protected String[] getServletMappings() {
  3. return new String[]{"/"};
  4. }

我们将Spring DispatcherServlet注册到/路径。 这代替了DefaultServlet; 因此,我们必须在配置文件中注册一个默认的 servlet 处理器。

com/zetcode/config/WebConfig.java

  1. package com.zetcode.config;
  2. import org.springframework.context.annotation.Configuration;
  3. import org.springframework.web.servlet.config.annotation.DefaultServletHandlerConfigurer;
  4. import org.springframework.web.servlet.config.annotation.EnableWebMvc;
  5. import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;
  6. @Configuration
  7. @EnableWebMvc
  8. public class WebConfig implements WebMvcConfigurer {
  9. @Override
  10. public void configureDefaultServletHandling(DefaultServletHandlerConfigurer configurer) {
  11. configurer.enable();
  12. }
  13. }

WebConfig通过@EnableWebMvc启用 Spring MVC,并通过DefaultServletHandlerConfigurerenable()方法配置DefaultServlet

  1. @Override
  2. public void configureDefaultServletHandling(DefaultServletHandlerConfigurer configurer) {
  3. configurer.enable();
  4. }

configureDefaultServletHandling()使用 URL 映射/**和相对于其他 URL 映射的最低优先级来配置DefaultServletHttpRequestHandler。 这样,静态资源请求由容器的默认 Servlet 处理。

webapp/index.html

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <title>Home page</title>
  6. </head>
  7. <body>
  8. <p>
  9. This is home page.
  10. </p>
  11. </body>
  12. </html>

这是主页。 它是静态资源,由DefaultServlet自动提供服务。

  1. $ curl localhost:8080
  2. <!DOCTYPE html>
  3. <html lang="en">
  4. <head>
  5. <meta charset="UTF-8">
  6. <title>Home page</title>
  7. </head>
  8. <body>
  9. <p>
  10. This is home page.
  11. </p>
  12. </body>
  13. </html>

当我们运行应用时,将提供主页。

在本教程中,我们展示了如何在 Spring 应用中注册默认 servlet。 您可能也对相关教程感兴趣:独立的 Spring 应用Spring WebSocket 教程Spring 自定义 404 错误页面教程,Spring WebApplicationInitializer教程,Spring Web 应用简介Java 教程