前言
最近跟着視頻在做一個分布式項目練練手,然后那個老師就說了下freemakker生成靜態頁面后,然后講了下思路:添加商品時生成對應的商品靜態頁面,訪問通過nginx來訪問靜態頁面,但是之后就啥也沒做了
nginx我就懶得下載以及搭建了,直接用tomcat來代替,我的思路是這樣:訪問商品詳情頁面時,先判斷有沒有對應的靜態頁面,有就返回html,沒有就走數據庫然后返回jsp。
剛開始還傻傻認為springmvc既然jsp也能解析,html也沒啥毛病,直接返回html,呵呵,果然不行。
下面是我自己的過往經驗和度娘結合歷經的坑:
1.首先我做的是偽靜態,dispatcherServlet的攔截路徑是*.html
<servlet-mapping> <servlet-name>e3-item-web</servlet-name> <!-- 偽靜態化 --> <url-pattern>*.html</url-pattern> </servlet-mapping>
那我返回的html應該被springmvc給攔截,那我加資源映射不就行了嘛(item文件夾在webapp下,用來存放生成的html頁面的)
<mvc:resources location="/item/" mapping="/item/**"></mvc:resources>
結果不行,找不到頁面,其實我也納悶,按正常它攔截html頁面后發現找不到對應的處理器來處理,應該會找資源映射到我的item下去找的;這種方法以失敗告終!
2.看了一些博客,有人已經扯到了springmvc的 / 和 /* 的區別,弄到tomcat下的web.xml,真的分析很透徹,我都被它的文章給征服了。文章建議到項目的web.xml下加下面的語句:
<servlet-mapping> <servlet-name>jsp</servlet-name> <url-pattern>*.html</url-pattern> </servlet-mapping>
然后我就屁顛屁顛得加上了,再然后...不行。還有其他文章跟它 的做法類似,比如加入下面的這個:
<servlet-mapping> <servlet-name>default</servlet-name> <url-pattern>*.html</url-pattern> </servlet-mapping>
好,這類方式也是以失敗告終,其實當時挺崩潰的,畢竟只是返回個html就得那么麻煩,不過還是建議大家不要用tomcat返回html頁面,效率和性能上沒有nginx好,是我自己作偷個懶
3.還有建議我自定義一個解析器,解析html頁面,不過我沒照做,因為代碼都是錯的,錯誤的東西就不放了。
4.然后確實有一篇文章真的可以返回html頁面,不過具體的做法我就不貼了,因為有缺陷,它是直接把html頁面當作jsp來解析了,按它的做法做,html行了,然后jsp就解析不了,我的需求是根據判斷是返回html還是jsp,兩個都能解析,所以這種方式我也沒采納
5.我還嘗試過用原生的request和response來轉發和重定向到頁面,還是不行,那個建議的哥們還很自信得說用requst不就行了嘛,呵呵
6.其實還有一些坑,不過就不詳細說了,畢竟大家是來找解決方法的,不是聽我訴苦,下面講我的解決方案。
解決方案:
因為我springmvc.xml配置的是攔截html,我靈機一動,html頁面的后綴也不只是html,不是還有htm嘛,於是我把生成的靜態頁面的代碼后綴改成htm,然后controller的handler方法返回htm,果然springmvc沒攔截我的請求,頁面也能展示,但是會亂碼,在說亂碼解決方法前,我說一些小問題:
1.由於你jsp和html都要能返回,那在配置文件就不要配置后綴了,前綴看你具體的存儲位置看要不要配
2.返回的路徑,以“/”開頭是相對於webapp下的
返回的html頁面亂碼解決方案:
真的,這個html頁面亂碼,有人搞什么解析器,過濾器等等讓我配,一個都不行,之后直接一行代碼搞定,在<head>標簽添加下面一條語句:
<meta charset="utf-8" />
問題不就解決了嗎?還搞那么多花里胡哨的。之后我還得提醒下大家,你如果獲取了html頁面,下次再獲取時請刷新緩存,不然你發出的請求其實根本沒到服務器,瀏覽器直接給你返回之前的一個html頁面
好了,就到這里吧,如果你還是解決不了,歡迎到下面來留言,我們一起討論