您好,登錄后才能下訂單哦!
本篇文章給大家分享的是有關在Spring Boot中使用Controller實現控制頁面,小編覺得挺實用的,因此分享給大家學習,希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。
一.項目實例
1.項目結構
2.項目代碼
1).ActionController.Java:
package com.example.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 @RequestMapping("/action") public class ActionController { // 從 application.properties 中讀取配置,如取不到application.properties定義的值,則取默認值為Hello Shanhy @Value("${application.hello:Hello Shanhy}") private String hello; /** * 默認頁<br/> * @RequestMapping("/") 和 @RequestMapping 是有區別的 * 如果不寫參數,則為全局默認頁。 * 如果加了參數“/”,則只認為是根頁面。 */ @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 */ @RequestMapping("/page1") public ModelAndView page1(){ // 頁面位置 /WEB-INF/jsp/page/page1.jsp //page/page1:頁面路徑地址/頁面名稱 ModelAndView mav = new ModelAndView("page/page1"); mav.addObject("content", hello); return mav; } /** * 響應到JSP頁面page1(可以直接使用Model封裝內容,直接返回頁面字符串) */ @RequestMapping("/page2") public String page2(Model model){ // 頁面位置 /WEB-INF/jsp/page/page1.jsp model.addAttribute("content", hello + "(第二種)"); return "page/page1"; } }
2).application.properties:
spring.mvc.view.prefix=/WEB-INF/jsp/ spring.mvc.view.suffix=.jsp application.hello=Hello TOM
3).index.jsp:
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <title>Spring Boot Sample</title> </head> <body> Time: ${time} <br> Message: ${message} </body> </html>
4).page1.jsp:
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <title>Spring Boot Sample</title> </head> <body> <h2>${content }</h2>: ${message} </body> </html>
5).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>com.example</groupId> <artifactId>Spring-boot-simple</artifactId> <version>0.0.1-SNAPSHOT</version> <!-- <packaging>jar</packaging> --> <packaging>war</packaging> <name>Spring-boot-simple</name> <description>Demo project for Spring Boot</description> <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>1.5.2.RELEASE</version> <relativePath/> <!-- lookup parent from repository --> </parent> <properties> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding> <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-test</artifactId> <scope>test</scope> </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> </dependencies> <build> <plugins> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> </plugin> </plugins> </build> </project>
3.運行啟動項目
訪問web地址:http://localhost:8080/action/ ,如下所示:
二.代碼解析說明
1.關于在Spring4.x中,@RestController和@Controller的區別
@RestController注解相當于@ResponseBody + @Controller合在一起的作用。所以,以后定義controller的時候,可以直接使用@Controller,如果需要返回json可以直接在方法中添加@ResponseBody即可。
a).如果只是使用@RestController注解Controller,則Controller中的方法無法返回jsp頁面,配置的視圖解析器InternalResourceViewResolver則不起作用,返回的內容就是Return 里的內容(String/JSON)。
例如:本來應該到success.jsp頁面的,則其顯示success.
public String test(HttpServletRequest request, HttpServletResponse response){ return "success"; }
b).如果使用@RestController注解Controller,需要返回到指定頁面,則需要配置視圖解析器InternalResourceViewResolver,可以利用ModelAndView返回試圖。
@RequestMapping(value = "/test") public String test(HttpServletRequest request, HttpServletResponse response){ return newModelAndView("success"); } c).如果使用@Controller注解Controller,如果需要返回JSON,XML或自定義mediaType內容到頁面,則需要在對應的方法上加上@ResponseBody注解。 @ResponseBody @RequestMapping(value = "/test") public String test(HttpServletRequest request, HttpServletResponse response){ return "success"; }
2.spring-boot 支持多種模版引擎包括:
a,FreeMarker
b,Groovy
c,Thymeleaf (Spring 官網使用這個)
d,Velocity
e,JSP (貌似Spring Boot官方不推薦,STS創建的項目會在src/main/resources 下有個templates 目錄,這里就是讓我們放模版文件的,然后并沒有生成諸如 SpringMVC 中的webapp目錄)
以上就是在Spring Boot中使用Controller實現控制頁面,小編相信有部分知識點可能是我們日常工作會見到或用到的。希望你能通過這篇文章學到更多知識。更多詳情敬請關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。