springmvc如何設置多視圖器,springmvc 多個 ViewResolver

springmvc如何設置多視圖器,springmvc 多個 ViewResolver

標籤: spring mvcspringmvc 多視圖解析器
17474人閱讀 評論(3) 收藏 舉報
本文章已收錄於:
category_icon.jpg分類:

再做頁面靜態化處理時,有時候我們需要 兩種或者兩種以上的視圖解析方式,比如 jsp,html,json,jstl,ftl等等,顯然默認的 springmvc 只配置一種視圖解析方式是滿足不了我們的,但是放心,springmvc提供了配置多視圖解析的方式:

比如:一種視圖解析用來 解析 freemarker靜態化後的html,另一種視圖解析用來解析 jsp(jstl)

網上好多方式都有提到用 order 來設置解析器的優先級,但經試驗,優先級低的還是生效不了,不知道是否有其他的解決方法?最終查看源碼才發現原來springmvc 只給我們提供了 待我們重寫的方法,看源碼:

  1. /*** Eclipse Class Decompiler plugin, copyright (c) 2012 Chao Chen ([email protected]) ***/  
  2. package org.springframework.web.servlet.view;  
  3.   
  4. import java.util.Locale;  
  5. import org.springframework.beans.factory.InitializingBean;  
  6.   
  7. public abstract class AbstractUrlBasedView extends AbstractView implements  
  8.         InitializingBean {  
  9.     private String url;  
  10.   
  11.     protected AbstractUrlBasedView() {  
  12.     }  
  13.   
  14.     protected AbstractUrlBasedView(String url) {  
  15.         this.url = url;  
  16.     }  
  17.   
  18.     public void setUrl(String url) {  
  19.         this.url = url;  
  20.     }  
  21.   
  22.     public String getUrl() {  
  23.         return this.url;  
  24.     }  
  25.   
  26.     public void afterPropertiesSet() throws Exception {  
  27.         if ((isUrlRequired()) && (getUrl() == null))  
  28.             throw new IllegalArgumentException("Property 'url' is required");  
  29.     }  
  30.   
  31.     protected boolean isUrlRequired() {  
  32.         return true;  
  33.     }  
  34.   
  35.     <span style="background-color: rgb(255, 255, 204);">public boolean checkResource(Locale locale) throws Exception {  
  36.         return true;  
  37.     }</span>  
  38.   
  39.     public String toString() {  
  40.         StringBuilder sb = new StringBuilder(super.toString());  
  41.         sb.append("; URL [").append(getUrl()).append("]");  
  42.         return sb.toString();  
  43.     }  
  44. }  
/*** Eclipse Class Decompiler plugin, copyright (c) 2012 Chao Chen ([email protected]) ***/
package org.springframework.web.servlet.view;

import java.util.Locale;
import org.springframework.beans.factory.InitializingBean;

public abstract class AbstractUrlBasedView extends AbstractView implements
		InitializingBean {
	private String url;

	protected AbstractUrlBasedView() {
	}

	protected AbstractUrlBasedView(String url) {
		this.url = url;
	}

	public void setUrl(String url) {
		this.url = url;
	}

	public String getUrl() {
		return this.url;
	}

	public void afterPropertiesSet() throws Exception {
		if ((isUrlRequired()) && (getUrl() == null))
			throw new IllegalArgumentException("Property 'url' is required");
	}

	protected boolean isUrlRequired() {
		return true;
	}

	<span style="background-color: rgb(255, 255, 204);">public boolean checkResource(Locale locale) throws Exception {
		return true;
	}</span>

	public String toString() {
		StringBuilder sb = new StringBuilder(super.toString());
		sb.append("; URL [").append(getUrl()).append("]");
		return sb.toString();
	}
}

所以怎麼做就很明確了:

第一步:新建一個html的解析器並繼承 InternalResourceView 後重寫 checkResource

  1. package com.izhbg.typz.common.springmvc.view;  
  2.   
  3. import java.io.File;  
  4. import java.util.Locale;  
  5.   
  6. import org.springframework.web.servlet.view.InternalResourceView;  
  7. /** 
  8.  *  
  9. * @ClassName: HtmlResourceView  
  10. * @author caixl  
  11. * @date 2016-6-8 上午11:01:41  
  12. * 
  13.  */  
  14. public class HtmlResourceView extends InternalResourceView {  
  15.      @Override  
  16.      public boolean checkResource(Locale locale) {  
  17.       File file = new File(this.getServletContext().getRealPath("/") + getUrl());  
  18.       return file.exists();// 判斷該頁面是否存在  
  19.      }  
  20. }  
package com.izhbg.typz.common.springmvc.view;

import java.io.File;
import java.util.Locale;

import org.springframework.web.servlet.view.InternalResourceView;
/**
 * 
* @ClassName: HtmlResourceView 
* @author caixl 
* @date 2016-6-8 上午11:01:41 
*
 */
public class HtmlResourceView extends InternalResourceView {
	 @Override
	 public boolean checkResource(Locale locale) {
	  File file = new File(this.getServletContext().getRealPath("/") + getUrl());
	  return file.exists();// 判斷該頁面是否存在
	 }
}
第二步:在xml配置文件中 指定解析器的 viewClass爲該解析類

  1. <!-- 定義HTML文件的位置 -->  
  2.      <bean id="htmlviewResolver"    
  3.         class="org.springframework.web.servlet.view.InternalResourceViewResolver">   
  4.         <property name="viewClass" value="com.izhbg.typz.common.springmvc.view.HtmlResourceView"/>  
  5.         <property name="order" value="0" />  
  6.         <property name="prefix" value="/cms/"/>  
  7.         <property name="suffix" value=".html" />    
  8.         <property name="contentType" value="text/html;charset=UTF-8"></property>    
  9.     </bean>  
  10.     <!-- 定義JSP文件的位置 -->  
  11.     <bean id="jspViewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver">  
  12.         <property name="order" value="1" />  
  13.         <property name="prefix" value="/views/"/>  
  14.         <property name="suffix" value=".jsp"/>  
  15.     </bean>  
<!-- 定義HTML文件的位置 -->
	 <bean id="htmlviewResolver"  
        class="org.springframework.web.servlet.view.InternalResourceViewResolver"> 
        <property name="viewClass" value="com.izhbg.typz.common.springmvc.view.HtmlResourceView"/>
        <property name="order" value="0" />
        <property name="prefix" value="/cms/"/>
        <property name="suffix" value=".html" />  
        <property name="contentType" value="text/html;charset=UTF-8"></property>  
    </bean>
	<!-- 定義JSP文件的位置 -->
	<bean id="jspViewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver">
		<property name="order" value="1" />
		<property name="prefix" value="/views/"/>
		<property name="suffix" value=".jsp"/>
	</bean>
源碼可參考 開源項目:https://github.com/izhbg/typz


3
0

參考知識庫

img

Java 知識庫

img

Java EE知識庫

img

Java SE知識庫

更多資料請參考:
猜你在找
開源攝像機EasyCamera開發教程2017軟考軟件設計師下午案例分析視頻培訓課程前端自動化構建工具合集之webpackOpenGLPython大型網絡爬蟲項目開發實戰(全套)2017軟考系統集成項目管理工程師視頻教程精講 基礎知識(上)微信公衆平臺開發入門JavaScript大神之路第二季華爲工程師,帶你實戰C++微信公衆平臺開發進階
關閉
查看評論
3樓 mj5lucky 2017-03-09 19:37發表 [回覆] [引用] [舉報]
3_mj5lucky.jpg
好,不錯
2樓 RisonGao 2017-03-02 16:46發表 [回覆] [引用] [舉報]
3_shuitudiyi.jpg
youyong
1樓 qq_25430869 2016-10-22 04:59發表 [回覆] [引用] [舉報]
3_qq_25430869.jpg
感謝!
網上類似文章很多,很多複製的沒什麼用。
* 以上用戶言論只代表其個人觀點,不代表CSDN網站的觀點或立場
快速回復TOP
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章