Spring Boot Controller

63 篇文章 18 订阅

接上篇文章,HelloWorld程序中我们已经创建了一个HellController,里面包含了响应JSON的方法,本文针对Controller再做一下讲解。

回顾上篇文章,我们在Controller中使用 @RestController 注解,该注解是Spring 4.0引入的。查看源码可知其包含了 @Controller 和 @ResponseBody 注解。我们可以理解为 @Controller的增强版。专门为响应内容式的 Controller 而设计的,可以直接响应对象为JSON。
而 @Controller 用来响应页面,spring-boot 支持多种模版引擎包括:
1,FreeMarker
2,Groovy
3,Thymeleaf (Spring 官网使用这个)
4,Velocity
5,JSP (貌似Spring Boot官方不推荐,STS创建的项目会在src/main/resources 下有个templates 目录,这里就是让我们放模版文件的,然后并没有生成诸如 SpringMVC 中的webapp目录)
不过本文还是选择大家都熟悉的JSP来举例,因为使用JSP与默认支持的模版需要特殊处理,所以拿来举例更好。

关于Controller 方法可以接收参数使用@RequestBody、@RequestParam、@ModelAttribute、JSONObject、HttpEntity 等方式,皆与Spring的使用一样,这里不做赘述。

下面我们来说一下如何使用 @Controller 实现响应JSP页面(与SpringMVC也是一样使用)。
创建PageController,编码如下:

package org.springboot.sample.controller;

import java.util.Date;
import java.util.Map;

import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.servlet.ModelAndView;

@Controller
public class PageController {
	
	// 从 application.properties 中读取配置,如取不到默认值为Hello Shanhy
	@Value("${application.hell:Hello Shanhy}")
	private String hello = "Hello Shanhy";

	/**
	 * 默认页<br/>
	 * @RequestMapping("/") 和 @RequestMapping 是有区别的
	 * 如果不写参数,则为全局默认页,加入输入404页面,也会自动访问到这个页面。
	 * 如果加了参数“/”,则只认为是根页面。
	 *
	 * @return
	 * @author SHANHY
	 * @create  2016年1月5日
	 */
	@RequestMapping(value = {"/","/index"})
	public String index(Map<String, Object> model){
		// 直接返回字符串,框架默认会去 spring.view.prefix 目录下的 (index拼接spring.view.suffix)页面
		// 本例为 /WEB-INF/jsp/index.jsp
		model.put("time", new Date());
		model.put("message", this.hello);
		return "index";
	}
	
	/**
	 * 响应到JSP页面page1
	 *
	 * @return
	 * @author SHANHY
	 * @create  2016年1月5日
	 */
	@RequestMapping("/page1")
	public ModelAndView page1(){
		// 页面位置 /WEB-INF/jsp/page/page1.jsp
		ModelAndView mav = new ModelAndView("page/page1");
		mav.addObject("content", hello);
		return mav;
	}
	
	/**
	 * 响应到JSP页面page1(可以直接使用Model封装内容,直接返回页面字符串)
	 *
	 * @return
	 * @author SHANHY
	 * @create  2016年1月5日
	 */
	@RequestMapping("/page2")
	public String page2(Model model){
		// 页面位置 /WEB-INF/jsp/page/page1.jsp
		model.addAttribute("content", hello + "(第二种)");
		return "page/page1";
	}
}

pom.xml添加依赖:

		<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>

上面说了spring-boot 不推荐JSP,想使用JSP需要配置application.properties。
添加src/main/resources/application.properties内容:

# 页面默认前缀目录
spring.mvc.view.prefix=/WEB-INF/jsp/
# 响应页面默认后缀
spring.mvc.view.suffix=.jsp
# 自定义属性,可以在Controller中读取
application.hello=Hello Shanhy

在 src/main 下面创建 webapp/WEB-INF/jsp 目录用来存放我们的jsp页面。
index.jsp

<%@ page language="java" pageEncoding="UTF-8"%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<title>Spring Boot Sample</title>
</head>

<body>
	Time: ${time}
	<br>
	Message: ${message}
</body>
</html>

page1.jsp

<%@ page language="java" pageEncoding="UTF-8"%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<title>Spring Boot Sample</title>
</head>

<body>
	<h1>${content }</h1>
</body>
</html>

要想让spring-boot支持JSP,需要将项目打成war包。
我们做最后一点修改,修改pom.xml文件,将 jar 中的 jar 修改为 war

然后启动spring-boot服务。
访问页面查看结果:
http://localhost:8080
http://localhost:8080/page1
http://localhost:8080/page2

最后附上工程结构:
这里写图片描述

如果需要使用 FreeMarker 的同学,请按下面的方法说明修改:
1、去掉 application.properties 中的 spring.mvc.view.prefix 和 spring.mvc.view.suffix 配置。
2、将 .ftl 模版页面放到 resources/templates 中(如上面工程截图所示)
其中 error.ftl 是系统默认的错误页,内容自定。
3、修改 pom.xml ,如下:

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
	xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
	<modelVersion>4.0.0</modelVersion>

	<groupId>org.springboot.sample</groupId>
	<artifactId>spring-boot-sample</artifactId>
	<version>0.0.1-SNAPSHOT</version>
	<packaging>jar</packaging>
<!-- 	<packaging>war</packaging> -->

	<name>spring-boot-sample</name>
	<description>Spring Boot Sample Web Application</description>

	<parent>
		<groupId>org.springframework.boot</groupId>
		<artifactId>spring-boot-starter-parent</artifactId>
		<version>1.3.1.RELEASE</version>
		<relativePath/> <!-- lookup parent from repository -->
	</parent>

	<properties>
		<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
		<java.version>1.8</java.version>
	</properties>

	<dependencies>
		
<!-- 		<dependency> -->
<!-- 			<groupId>org.springframework.boot</groupId> -->
<!-- 			<artifactId>spring-boot-starter-web</artifactId> -->
<!-- 		</dependency> -->
<!-- 		<dependency> -->
<!-- 			<groupId>org.springframework.boot</groupId> -->
<!-- 			<artifactId>spring-boot-starter-tomcat</artifactId> -->
<!-- 		</dependency> -->
<!-- 		<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> -->
		<dependency>
			<groupId>org.springframework.boot</groupId>
			<artifactId>spring-boot-starter-test</artifactId>
			<scope>test</scope>
		</dependency>
		<dependency>
			<groupId>org.springframework.boot</groupId>
			<artifactId>spring-boot-starter-freemarker</artifactId>
		</dependency>
	</dependencies>
	
	<build>
		<plugins>
			<plugin>
				<groupId>org.springframework.boot</groupId>
				<artifactId>spring-boot-maven-plugin</artifactId>
			</plugin>
		</plugins>
	</build>
	

</project>
  • 39
    点赞
  • 45
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 50
    评论
### 回答1: Spring Boot控制器是一个Java类,用于处理HTTP请求并返回响应。它是Spring MVC框架的一部分,可以使用注解来定义请求映射和处理方法。Spring Boot控制器可以处理各种类型的请求,例如GET、POST、PUT和DELETE,并可以返回各种类型的响应,例如HTML、JSON和XML。它是构建Web应用程序的重要组件之一。 ### 回答2: Spring Boot是一个开发Web应用程序的框架,其使用@Controller注解声明的类是视图控制器。这个控制器接收来自HTTP请求的用户输入,将其转换为Java对象,并将其发送到应用程序的其他部分进行处理。 @Controller注解是一个Spring MVC注解,它将一个类标记为一个控制器,并且这个控制器可以处理HTTP请求。在Spring Boot,控制器类使用@Controller注解进行标记,该注解告诉Spring框架这个类是控制器,需要进行请求处理。此外,在@Controller注解上,还可以使用@RequestMapping注解进行更详细的声明,指定控制器类的特定处理函数处理哪些HTTP请求。 在Spring Boot,控制器类包含各种处理函数,以处理不同类型的用户输入。控制器类的每个处理函数都由Spring框架负责调用,这样,控制器类就可以将用户输入转换为Java对象,并将其发送到适当的处理程序进行处理。 总而言之,Spring Boot的控制器是一个非常重要的组件,用于接收并处理来自用户的HTTP请求。通过使用@Controller注解,Spring框架能够自动将请求路由到正确的处理程序,并在必要时将请求转换为Java对象。控制器类是Web应用程序的关键组成部分,可以帮助开发人员创建高效、可扩展的应用程序。 ### 回答3: Spring Boot ControllerSpring Boot 框架的一个组件,用于管理和处理来自网络的请求和响应。它是 MVC 模式的控制器,负责调度并响应浏览器或客户端发送的请求。 Spring Boot Controller 的最主要的功能就是接收来自浏览器、客户端等渠道的请求,然后根据请求的参数、路径信息等,从后端系统获取相应的数据,并将其封装成一个响应对象,最后通过网络返回给请求方。 Spring Boot Controller 实现一个简单的 GET 接口非常的简单,只需添加 @RestController 和 @RequestMapping 注解便可实现对外暴露的接口。 通过注解 @RequestMapping 可以指定该接口的请求路径、请求方式等信息。例如: @RestController @RequestMapping("/hello") public class HelloController { @GetMapping("/") public String hello() { return "Hello, World!"; } } 这个 Controller 配置了一个 GET 请求,访问路径为 "/hello/",返回值为 "Hello, World!"。 大多数Spring Boot Controller 都会从数据库、文件、或者其他接口获取数据,然后对这些数据进行处理。因此,在实现一个 Spring Boot Controller 的过程,通常还需要为其提供一个业务逻辑服务,以便能够从数据库或者其他接口获取数据并进行处理。业务逻辑服务通常会被注入到 Controller ,然后又被转换为 JSON 格式的响应对象返回给请求方。 因为 Spring Boot Controller 是 MVC 模式的控制器,实现它需要使用到一系列 Spring Boot 模块和组件,比如 Spring Boot Web、Spring Boot Data JPA、Spring Boot Test 等等。这些模块和组件的主要作用是简化和规范化 Spring Boot Controller 的开发和测试,提高开发效率。
评论 50
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

catoop

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值