一、Java模板引擎
模板引擎(這里特指用於Web開發的模板引擎)是為了使用戶界面與業務數據(內容)分離而產生的,它可以生成特定格式的文檔,用於網站的模板引擎就會生成一個標准的HTML文檔。
在java中,主要的模板引擎有JSP、Thymeleaf、FreeMarker、
Velocity等。
雖然隨着前后端分離的崛起和流行,模板引擎已遭受到冷落,但不少舊項目依然使用java的模板引擎渲染界面,而偶爾自己寫一些練手項目,使用模板引擎也比起前后端分離要來的快速。
本系列會分別講解SpringBoot怎么集成JSP、Thymeleaf和FreeMarker,至於Velocity,高版本的SpringBoot已經不支持Velocity了,這里也就不進行講解了。
而這一篇,主要講解Spring Boot如何集成JSP。
一、Spring Boot集成JSP
首先我們要引入依賴,除了核心的web依賴外,就是jstl和tomcat-embed-jasper了。
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<!--jsp頁面使用jstl標簽-->
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>jstl</artifactId>
</dependency>
<!-- 使用jsp引擎,springboot內置tomcat沒有此依賴 -->
<dependency>
<groupId>org.apache.tomcat.embed</groupId>
<artifactId>tomcat-embed-jasper</artifactId>
</dependency>
然后就是配置文件了。主要在spring.mvc.view節點下配置視圖目錄prefix和文件后綴suffix。
server:
port: 10900
spring:
profiles:
active: dev
mvc:
view:
prefix: /templates/ #view視圖文件(jsp)文件的存儲位置,不能直接放在resources目錄下,需要放在webapp目錄下
#prefix: /pages/ #或者resources下創建META-INF/resources目錄
suffix: .jsp #視圖文件后綴
這里配置了文件目錄為/templates/,需要主要注意的是,jsp無法直接放在resources目錄下,默認會去src/main/webapp目錄下去尋找,如果沒有,則會去src/main/resources/MATE-INF/resources目錄去尋找,因此使用JSP,我們就需要將JSP文件放在這兩個目錄下,而配置的/templates/,即為src/main/webapp/templates或者src/main/resources/MATE-INF/resources/templates。
在src/main下創建webapp/templates目錄,分別新建了hello.jsp和mv.jsp文件。
<h3>hello jsp</h3>
<h3>mv jsp</h3>
<span>I'm ${name} from mv method</span>
這里主要講解如何集成JSP,不對JSP語法做過多的講解,所以僅僅提供了兩個簡單的JSP文件,並簡單使用el表達式${name}取值。
接着再創建Controller類路由頁面,該類也十分簡單,跳轉hello頁面,以及攜帶name=imyang跳轉mv頁面。
@Controller
@RequestMapping("index")
public class Index {
@RequestMapping("/hello")
public String hello(){
return "hello";
}
@RequestMapping("/mv")
public ModelAndView mv(){
ModelAndView mv = new ModelAndView("mv");
mv.addObject("name","yanger");
return mv;
}
}
啟動項目,分別訪問http://localhost:10900/index/hello和http://localhost:10900/index/mv,可以看到已經可以展示頁面信息了。
源碼地址:https://github.com/imyanger/springboot-project/tree/master/p17-springboot-jsp