詳解Spring Boot 添加JSP支持
大體步驟:
(1)創(chuàng)建Maven web project;
(2)在pom.xml文件添加依賴;
(3)配置application.properties支持jsp
(4)編寫測試Controller
(5)編寫JSP頁面
(6)編寫啟動類Application.Java
1,F(xiàn)reeMarker
2,Groovy
3,Thymeleaf (spring 官網(wǎng)使用這個)
4,Velocity
5,JSP (貌似Spring Boot官方不推薦,STS創(chuàng)建的項目會在src/main/resources 下有個templates 目錄,這里就是讓我們放模版文件的,然后并沒有生成諸如 SpringMVC 中的webapp目錄)
不過本文還是選擇大家都熟悉的JSP來舉例,因為使用JSP與默認支持的模版需要特殊處理,所以拿來舉例更好。
(1)創(chuàng)建Maven web project
使用Eclipse新建一個Maven Web Project ,項目取名為:
spring-boot-jsp
(2)在pom.xml文件添加依賴
<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-jsp</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>war</packaging>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
</properties>
<!-- Inherit defaults from Spring Boot -->
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>1.4.0.RELEASE</version>
</parent>
<dependencies>
<!-- web支持: 1、web mvc; 2、restful; 3、jackjson支持; 4、aop ........ -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<!-- servlet 依賴. -->
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>javax.servlet-api</artifactId>
<scope>provided</scope>
</dependency>
<!-- JSTL(JSP Standard Tag Library,JSP標準標簽庫)是一個不斷完善的開放源代碼的JSP標簽庫,是由apache的jakarta小組來維護的。JSTL只能運行在支持JSP1.2和Servlet2.3規(guī)范的容器上,如tomcat
4.x。在JSP 2.0中也是作為標準支持的。 不然報異常信息: javax.servlet.ServletException: Circular
view path [/helloJsp]: would dispatch back to the current handler URL [/helloJsp]
again. Check your ViewResolver setup! (Hint: This may be the result of an
unspecified view, due to default view name generation.) -->
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>jstl</artifactId>
</dependency>
<!-- tomcat 的支持. -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-tomcat</artifactId>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>org.apache.tomcat.embed</groupId>
<artifactId>tomcat-embed-jasper</artifactId>
<scope>provided</scope>
</dependency>
</dependencies>
<build>
<finalName>spring-boot-jsp</finalName>
<plugins>
<plugin>
<artifactId>maven-compiler-plugin</artifactId>
<configuration>
<source>1.8</source>
<target>1.8</target>
</configuration>
</plugin>
</plugins>
</build>
</project>
(3)application.properties配置
上面說了spring-boot 不推薦JSP,想使用JSP需要配置application.properties。
添加src/main/resources/application.properties內(nèi)容:
# 頁面默認前綴目錄 spring.mvc.view.prefix=/WEB-INF/jsp/ # 響應頁面默認后綴 spring.mvc.view.suffix=.jsp # 自定義屬性,可以在Controller中讀取 application.hello=Hello Angel From application
(4)編寫測試Controller
package com.example.jsp.controller;
import java.util.Map;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
@Controller
public class HelloController {
//從application中讀取配置,如取不到默認值為hello jack
@Value("${application.hello:hello jack}")
private String hello;
@RequestMapping("/helloJsp")
public String helloJsp(Map<String, Object> map){
System.out.println("HelloController.helloJsp().hello="+hello);
map.put("hello", hello);
return "helloJsp";
}
}
(5)編寫JSP頁面
在 src/main 下面創(chuàng)建 webapp/WEB-INF/jsp 目錄用來存放我們的jsp頁面:helloJsp.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>Insert title here</title>
</head>
<body>
helloJsp
<hr>
${hello}
</body>
</html>
6)編寫啟動類
編寫Application.java啟動類:
package com.example;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.boot.web.support.SpringBootServletInitializer;
//import org.springframework.boot.context.web.SpringBootServletInitializer;
@SpringBootApplication
public class Application extends SpringBootServletInitializer {
public static void main(String[] args){
SpringApplication.run(Application.class, args);
}
}
右鍵Run As Java Application訪問:http://127.0.0.1:8080/helloJsp 可以訪問到:
helloJsp
Hello Angel From application
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
Spring Boot2.x集成JPA快速開發(fā)的示例代碼
這篇文章主要介紹了Spring Boot2.x集成JPA快速開發(fā),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-05-05
Java UrlRewriter偽靜態(tài)技術運用深入分析
通常我們?yōu)榱烁玫木徑夥掌鲏毫?和增強搜索引擎的友好面,都將文章內(nèi)容生成靜態(tài)頁面,這就產(chǎn)生了偽靜態(tài)技術,也就是我們常說的Url Rewriter重寫技術2012-12-12
SpringCloud整合OpenFeign實現(xiàn)微服務間的通信
微服務之間的通信?式,通常有兩種: RPC 和 HTTP,在SpringCloud中, 默認是使?HTTP來進?微服務的通信, 最常?的實現(xiàn)形式有兩種:RestTemplate和OpenFeign,本文給大家介紹了SpringCloud整合OpenFeign實現(xiàn)微服務間的通信,需要的朋友可以參考下2024-06-06

