原文: https://howtodoinjava.com/spring-mvc/spring-mvc-hello-world-example/

在此示例中,我们将使用 Spring MVC 框架构建一个 Hello World Web 应用程序。 Spring MVC 是 Spring 框架的最重要模块之一。 它基于功能强大的 Spring IoC 容器 构建,并广泛使用了容器功能以简化其配置。

  1. Table Of Contents
  2. What is MVC Framework?
  3. Dispatcher Servlet (Spring Controller)
  4. Spring MVC Hello World Example
  5. Runtime Dependencies
  6. Configuration Files web.xml and spring-servlet.xml
  7. Request Handler EmployeeController.java
  8. View Model EmployeeVO.java
  9. Dao Classes
  10. Service layer Classes
  11. View employeesListDisplay.jsp

下载源码

什么是 MVC 框架?

模型视图控制器(MVC) 是众所周知的 设计模式 ,用于设计基于 UI 的应用程序。 它主要通过在应用程序中分离模型,视图和控制器的角色来将业务逻辑与 UI 分离。 通常,模型负责封装应用程序数据以呈现视图。 视图仅应显示此数据,而不包括任何业务逻辑。 控制器负责接收来自用户的请求并调用后端服务(管理器或 dao)进行业务逻辑处理。 处理后,后端服务可能会返回一些数据以供视图显示。 控制器收集这些数据并准备模型以供视图显示。 MVC 模式的核心思想是将业务逻辑与 UI 分开,以允许它们独立更改而不会互相影响。

Spring MVC Hello World 示例 - 图1

在 Spring MVC 应用程序中,模型通常由 POJO 对象组成,这些对象由服务层处理并由持久层持久化。 视图通常是使用 Java 标准标记库(JSTL)编写的 JSP 模板。 控制器部分由调度程序 servlet 扮演,我们将在本教程中详细了解。

一些开发人员将服务层和 DAO 层类视为 MVC 中模型组件的一部分。 我对此有不同的看法。 我不认为服务层和 DAO 层类是 MVC 框架的一部分。 通常,Web 应用程序是 3 层体系结构,即数据服务表示。MVC 实际上是表示层的一部分。

Spring MVC Hello World 示例 - 图2

分派器 Servlet(Spring 控制器)

在最简单的 Spring MVC 应用程序中,控制器是您唯一需要在 Java Web 部署描述符(即web.xml文件)中配置的 servlet。 一个 Spring MVC 控制器(通常称为分派器 Servlet)实现前端控制器设计模式,每个 Web 请求都必须经过它,以便它可以管理整个请求生命周期。

将 Web 请求发送到 Spring MVC 应用程序时,调度程序 Servlet 首先接收该请求。 然后,它会组织在 Spring 的 Web 应用程序上下文中配置的不同组件(例如,实际的请求处理器控制器和视图解析器)或控制器本身中存在的注解,这些都是处理请求所需的。

Spring MVC Hello World 示例 - 图3

Spring 分派器 servlet

要在 Spring 3.0 中定义控制器类,必须使用@Controller注解标记一个类。 当带@Controller的带注解的控制器接收到请求时,它将寻找适当的处理器方法来处理该请求。 这要求控制器类通过一个或多个处理器映射将每个请求映射到一个处理器方法。 为此,控制器类的方法用@RequestMapping注解修饰,使其成为处理器方法。

处理器方法处理完请求后,它将控制权委派给一个视图,该视图表示为处理器方法的返回值。 为了提供一种灵活的方法,处理器方法的返回值并不代表视图的实现,而是逻辑视图,即没有任何文件扩展名。 您可以将这些逻辑视图正确地映射到applicationContext文件中,这样就可以轻松更改视图层代码,甚至无需触摸请求处理器类代码。

视图解析器负责为逻辑名称解析正确的文件。 根据视图实现的设计,控制器类将视图名称解析为视图实现后,便会呈现对象。

Spring MVC Hello World 示例

在此应用程序中,我将创建仅具有一项功能的最简单的员工管理应用程序演示,即列出系统中所有可用的员工。 让我们记下该应用程序的目录结构。

Spring MVC Hello World 示例 - 图4

Spring mvc hello world 目录结构

现在,将所有涉及的文件写入此 hello world 应用程序中。

pom.xml

pom.xml下面的文件包含 spring mvc 的依赖项和用于编写 jsp 文件的 taglibs 支持。

  1. <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  2. xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
  3. <modelVersion>4.0.0</modelVersion>
  4. <groupId>com.howtodoinjava.demo</groupId>
  5. <artifactId>springmvcexample</artifactId>
  6. <packaging>war</packaging>
  7. <version>1.0-SNAPSHOT</version>
  8. <name>springmvcexample Maven Webapp</name>
  9. <url>http://maven.apache.org</url>
  10. <dependencies>
  11. <dependency>
  12. <groupId>junit</groupId>
  13. <artifactId>junit</artifactId>
  14. <version>4.12</version>
  15. <scope>test</scope>
  16. </dependency>
  17. <!-- Spring MVC support -->
  18. <dependency>
  19. <groupId>org.springframework</groupId>
  20. <artifactId>spring-webmvc</artifactId>
  21. <version>4.1.4.RELEASE</version>
  22. </dependency>
  23. <dependency>
  24. <groupId>org.springframework</groupId>
  25. <artifactId>spring-web</artifactId>
  26. <version>4.1.4.RELEASE</version>
  27. </dependency>
  28. <!-- Tag libs support for view layer -->
  29. <dependency>
  30. <groupId>javax.servlet</groupId>
  31. <artifactId>jstl</artifactId>
  32. <version>1.2</version>
  33. <scope>runtime</scope>
  34. </dependency>
  35. <dependency>
  36. <groupId>taglibs</groupId>
  37. <artifactId>standard</artifactId>
  38. <version>1.1.2</version>
  39. <scope>runtime</scope>
  40. </dependency>
  41. </dependencies>
  42. <build>
  43. <finalName>springmvcexample</finalName>
  44. </build>
  45. </project>

web.xml

这个最小的web.xml文件声明了一个 servlet(即调度程序 servlet)来接收所有类型的请求。 调度程序 servlet 在这里充当前端控制器。

  1. <web-app id="WebApp_ID" version="2.4"
  2. xmlns="http://java.sun.com/xml/ns/j2ee"
  3. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  4. xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee
  5. http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd">
  6. <display-name>Spring Web MVC Hello World Application</display-name>
  7. <servlet>
  8. <servlet-name>spring</servlet-name>
  9. <servlet-class>
  10. org.springframework.web.servlet.DispatcherServlet
  11. </servlet-class>
  12. <load-on-startup>1</load-on-startup>
  13. </servlet>
  14. <servlet-mapping>
  15. <servlet-name>spring</servlet-name>
  16. <url-pattern>/</url-pattern>
  17. </servlet-mapping>
  18. </web-app>

spring-servlet.xml(也可以有 applicationContext.xml

我们在请求处理器,服务和 dao 层上使用带注解的类,因此我已对基本包“ com.howtodoinjava.demo”中的所有类文件启用了注解处理。

  1. <beans xmlns="http://www.springframework.org/schema/beans"
  2. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  3. xmlns:context="http://www.springframework.org/schema/context"
  4. xsi:schemaLocation="http://www.springframework.org/schema/beans
  5. http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
  6. http://www.springframework.org/schema/context/
  7. http://www.springframework.org/schema/context/spring-context-3.0.xsd">
  8. <context:component-scan base-package="com.howtodoinjava.demo" />
  9. <bean class="org.springframework.web.servlet.mvc.annotation.DefaultAnnotationHandlerMapping" />
  10. <bean class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter" />
  11. <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
  12. <property name="prefix" value="/WEB-INF/views/" />
  13. <property name="suffix" value=".jsp" />
  14. </bean>
  15. </beans>

EmployeeController.java

类级别和方法级别的注解@RequestMapping确定将在其中调用方法的 URL。

  1. import org.springframework.beans.factory.annotation.Autowired;
  2. import org.springframework.stereotype.Controller;
  3. import org.springframework.ui.Model;
  4. import org.springframework.web.bind.annotation.RequestMapping;
  5. import org.springframework.web.bind.annotation.RequestMethod;
  6. import com.howtodoinjava.demo.service.EmployeeManager;
  7. @Controller
  8. @RequestMapping("/employee-module")
  9. public class EmployeeController
  10. {
  11. @Autowired
  12. EmployeeManager manager;
  13. @RequestMapping(value = "/getAllEmployees", method = RequestMethod.GET)
  14. public String getAllEmployees(Model model)
  15. {
  16. model.addAttribute("employees", manager.getAllEmployees());
  17. return "employeesListDisplay";
  18. }
  19. }

阅读更多:如何使用@Component@Repository@Service@Controller注解?

EmployeeVO.java

此类充当 MVC 模式的模型。

  1. package com.howtodoinjava.demo.model;
  2. import java.io.Serializable;
  3. public class EmployeeVO implements Serializable
  4. {
  5. private static final long serialVersionUID = 1L;
  6. private Integer id;
  7. private String firstName;
  8. private String lastName;
  9. //Setters and Getters
  10. @Override
  11. public String toString() {
  12. return "EmployeeVO [id=" + id + ", firstName=" + firstName
  13. + ", lastName=" + lastName + "]";
  14. }
  15. }

EmployeeDAO.java

三层体系结构中第三层的类。 负责与基础数据库存储进行交互。

  1. import java.util.List;
  2. import com.howtodoinjava.demo.model.EmployeeVO;
  3. public interface EmployeeDAO
  4. {
  5. public List<EmployeeVO> getAllEmployees();
  6. }

EmployeeDAOImpl.java

  1. import java.util.ArrayList;
  2. import java.util.List;
  3. import org.springframework.stereotype.Repository;
  4. import com.howtodoinjava.demo.model.EmployeeVO;
  5. @Repository
  6. public class EmployeeDAOImpl implements EmployeeDAO {
  7. public List<EmployeeVO> getAllEmployees()
  8. {
  9. List<EmployeeVO> employees = new ArrayList<EmployeeVO>();
  10. EmployeeVO vo1 = new EmployeeVO();
  11. vo1.setId(1);
  12. vo1.setFirstName("Lokesh");
  13. vo1.setLastName("Gupta");
  14. employees.add(vo1);
  15. EmployeeVO vo2 = new EmployeeVO();
  16. vo2.setId(2);
  17. vo2.setFirstName("Raj");
  18. vo2.setLastName("Kishore");
  19. employees.add(vo2);
  20. return employees;
  21. }
  22. }

EmployeeManager.java

3 层体系结构中第二层的类。 负责与 DAO 层进行交互。

  1. import java.util.List;
  2. import com.howtodoinjava.demo.model.EmployeeVO;
  3. public interface EmployeeManager
  4. {
  5. public List<EmployeeVO> getAllEmployees();
  6. }

EmployeeManagerImpl.java

  1. import java.util.List;
  2. import org.springframework.beans.factory.annotation.Autowired;
  3. import org.springframework.stereotype.Service;
  4. import com.howtodoinjava.demo.dao.EmployeeDAO;
  5. import com.howtodoinjava.demo.model.EmployeeVO;
  6. @Service
  7. public class EmployeeManagerImpl implements EmployeeManager {
  8. @Autowired
  9. EmployeeDAO dao;
  10. public List<EmployeeVO> getAllEmployees()
  11. {
  12. return dao.getAllEmployees();
  13. }
  14. }

employeeListDisplay.jsp

该 jsp 用于显示系统中的所有员工。 它循环遍历员工集合,并将其详细信息打印在表中。 这适合 MVC 模式的视图层。

  1. <%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core"%>
  2. <%@ taglib prefix="fmt" uri="http://java.sun.com/jsp/jstl/fmt"%>
  3. <html>
  4. <head>
  5. <title>Spring MVC Hello World</title>
  6. </head>
  7. <body>
  8. <h2>All Employees in System</h2>
  9. <table border="1">
  10. <tr>
  11. <th>Employee Id</th>
  12. <th>First Name</th>
  13. <th>Last Name</th>
  14. </tr>
  15. <c:forEach items="${employees}" var="employee">
  16. <tr>
  17. <td>${employee.id}</td>
  18. <td>${employee.firstName}</td>
  19. <td>${employee.lastName}</td>
  20. </tr>
  21. </c:forEach>
  22. </table>
  23. </body>
  24. </html>

现在将应用程序部署到您的应用程序服务器中(我正在使用 tomcat 7)。 并点击 URL http://localhost:8080/springmvcexample/employee-module/getAllEmployees。 如果正确配置了所有内容,则会在下面的屏幕上看到。

Spring MVC Hello World 示例 - 图5

应用前端 UI

下载源码

如果某些内容不适合您或在本教程中不清楚,请给我留言。

祝您学习愉快!