Spring Boot的Controller控制層和頁面
一.項目實例
1.項目結(jié)構(gòu)
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 是有區(qū)別的 * 如果不寫參數(shù),則為全局默認頁。 * 如果加了參數(shù)“/”,則只認為是根頁面。 */ @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封裝內(nèi)容,直接返回頁面字符串) */ @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> <h1>${content }</h1>: ${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的區(qū)別
@RestController注解相當于@ResponseBody + @Controller合在一起的作用。所以,以后定義controller的時候,可以直接使用@Controller,如果需要返回json可以直接在方法中添加@ResponseBody即可。
a).如果只是使用@RestController注解Controller,則Controller中的方法無法返回jsp頁面,配置的視圖解析器InternalResourceViewResolver則不起作用,返回的內(nèi)容就是Return 里的內(nèi)容(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內(nèi)容到頁面,則需要在對應的方法上加上@ResponseBody注解。 @ResponseBody @RequestMapping(value = "/test") public String test(HttpServletRequest request, HttpServletResponse response){ return "success"; }
2.spring-boot 支持多種模版引擎包括:
a,F(xiàn)reeMarker
b,Groovy
c,Thymeleaf (Spring 官網(wǎng)使用這個)
d,Velocity
e,JSP (貌似Spring Boot官方不推薦,STS創(chuàng)建的項目會在src/main/resources 下有個templates 目錄,這里就是讓我們放模版文件的,然后并沒有生成諸如 SpringMVC 中的webapp目錄)
以上所述是小編給大家介紹的Spring Boot的Controller控制層和頁面,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關文章
基于Mybatis plus 自動代碼生成器的實現(xiàn)代碼
本文通過實例代碼給大家介紹了基于Mybatis-plus 自動代碼生成器的相關知識,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下2018-05-05Java使用Thumbnailator實現(xiàn)圖片處理功能
Thumbnailator是一個簡單且功能強大的Java庫,用于生成縮略圖和執(zhí)行其他圖片處理任務,在這篇博客中,我們將介紹如何使用Thumbnailator進行圖片的縮放、裁剪、旋轉(zhuǎn)等操作,需要的朋友可以參考下2024-07-07