原文: http://zetcode.com/springboot/controller/

Spring Boot @Controller教程显示了如何在 Spring 应用中使用@Controller注解来构建 Web 控制器。

Spring 是流行的 Java 应用框架,而 Spring Boot 是 Spring 的演进,可以帮助轻松地创建独立的,生产级的基于 Spring 的应用。

Spring MVC

Spring MVC 是基于 Servlet API 构建的原始 Web 框架。 它基于流行的 MVC 设计模式。 MVC(模型-视图-控制器)是一种软件架构模式,它将应用分为三个区域:模型,视图和控制器。 该模型表示一个携带数据的 Java 对象。 该视图表示模型包含的数据的可视化。 控制器控制数据流入模型对象并在数据更改时更新视图。 它使视图和模型分离。

Spring Framework 5.0 引入了一个名为 Spring WebFlux 的并行反应式栈 Web 框架。

@Controller

@Controller注解指示已注解的类是控制器。 它是@Component的特化,可通过类路径扫描自动检测。 它通常与基于@RequestMapping注解的注解处理器方法结合使用。 @RestController是用于创建 Restful 控制器的同级便利注解。

Spring Boot @Controller示例

在以下应用中,我们演示@Controller的用法。 该应用将当前数据和时间返回给客户端。

  1. $ tree
  2. .
  3. ├── pom.xml
  4. └── src
  5. ├── main
  6. ├── java
  7. └── com
  8. └── zetcode
  9. ├── Application.java
  10. └── controller
  11. └── MyController.java
  12. └── resources
  13. ├── static
  14. └── index.html
  15. └── templates
  16. └── showMessage.ftl
  17. └── test
  18. └── java

这是 Spring 应用的项目结构。

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>controllerex</artifactId>
  9. <version>1.0-SNAPSHOT</version>
  10. <packaging>jar</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. <parent>
  17. <groupId>org.springframework.boot</groupId>
  18. <artifactId>spring-boot-starter-parent</artifactId>
  19. <version>2.1.1.RELEASE</version>
  20. </parent>
  21. <dependencies>
  22. <dependency>
  23. <groupId>org.springframework.boot</groupId>
  24. <artifactId>spring-boot-starter-web</artifactId>
  25. </dependency>
  26. <dependency>
  27. <groupId>org.springframework.boot</groupId>
  28. <artifactId>spring-boot-starter-freemarker</artifactId>
  29. </dependency>
  30. </dependencies>
  31. <build>
  32. <plugins>
  33. <plugin>
  34. <groupId>org.springframework.boot</groupId>
  35. <artifactId>spring-boot-maven-plugin</artifactId>
  36. </plugin>
  37. </plugins>
  38. </build>
  39. </project>

这是 Maven pom.xml文件。 spring-boot-starter-parent是父 POM,它为使用 Maven 构建的应用提供依赖关系和插件管理。 spring-boot-starter-freemarker是 Freemarker 模板引擎的依赖项。 此依赖项还将在项目中包含 Spring MVC。 spring-boot-maven-plugin将 Spring 应用打包到可执行的 JAR 或 WAR 归档文件中。

com/zetcode/MyController.java

  1. package com.zetcode.controller;
  2. import org.springframework.stereotype.Controller;
  3. import org.springframework.web.bind.annotation.RequestMapping;
  4. import org.springframework.web.servlet.ModelAndView;
  5. import java.time.LocalDateTime;
  6. import java.time.format.DateTimeFormatter;
  7. import java.util.HashMap;
  8. @Controller
  9. public class MyController {
  10. @RequestMapping(value = "/getDateAndTime")
  11. public ModelAndView getDateAndTime() {
  12. var now = LocalDateTime.now();
  13. var dtf = DateTimeFormatter.ofPattern("yyyy/MM/dd HH:mm:ss");
  14. var date_time = dtf.format(now);
  15. var params = new HashMap<String, Object>();
  16. params.put("date_time", date_time);
  17. return new ModelAndView("showMessage", params);
  18. }
  19. }

这是MyController。 它响应来自客户端的请求。 它找出当前日期和时间,并将处理过程解析为showMessage.ftl模板,并将其传递给数据。

  1. @Controller
  2. public class MyController {

MyController带有@Controller注解。

  1. @RequestMapping(value = "/getDateAndTime")
  2. public ModelAndView getDateAndTime() {

getDateAndTime()方法映射到getDateAndTime URL 模式; 它返回ModelAndView,它是 Web MVC 框架中 Model 和 View 的持有者。

  1. var now = LocalDateTime.now();
  2. var dtf = DateTimeFormatter.ofPattern("yyyy/MM/dd HH:mm:ss");
  3. var date_time = dtf.format(now);

我们获取并格式化本地日期和时间。

  1. var params = new HashMap<String, Object>();
  2. params.put("date_time", date_time);

日期和时间字符串将添加到参数映射中。

  1. return new ModelAndView("showMessage", params);

我们返回ModelAndView。 由于 POM 文件中存在 Freemarker 依赖项,因此 Spring 将处理解析为showMessage.ftl模板文件,并将params对象传递给它。

resources/static/index.html

  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <title>Home page</title>
  5. <meta charset="UTF-8">
  6. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  7. </head>
  8. <body>
  9. <p>
  10. <a href="getDateAndTime">Get date and time</a>
  11. </p>
  12. </body>
  13. </html>

这是主页。 它包含一个调用 Spring 控制器的链接。 它是静态资源,位于预定义的src/main/resources/static目录中。

resources/templates/showMessage.ftl

  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <title>Show message</title>
  5. <meta charset="UTF-8">
  6. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  7. </head>
  8. <body>
  9. Date and time: ${date_time}
  10. </body>
  11. </html>

showMessage.ftl是一个 Freemarker 模板文件。 它位于预定义的src/main/resources/templates目录中。 它使用${}语法输出日期和时间。

com/zetcode/Application.java

  1. package com.zetcode;
  2. import org.springframework.boot.SpringApplication;
  3. import org.springframework.boot.autoconfigure.SpringBootApplication;
  4. @SpringBootApplication
  5. public class Application {
  6. public static void main(String[] args) {
  7. SpringApplication.run(Application.class, args);
  8. }
  9. }

Application是设置 Spring Boot 应用的入口。 @SpringBootApplication注解启用自动配置和组件扫描。 在扫描过程中,将查找@Controller注解,并从MyController类创建一个 Spring bean。

  1. $ mvn spring-boot:run

应用运行后,我们可以导航到localhost:8080

在本教程中,我们展示了如何在 Spring 应用中使用@Controller注解。 您可能也对相关教程感兴趣: Spring Boot @RestController教程Java Servlets 教程Spring Boot @ResponseStatus教程Spring Boot @ExceptionHandler教程Spring Boot 上传文件Spring Boot @Component教程Spring Boot @RequestParam教程Java 教程