相信之前的教學文章已經可以讓你開始建構自己的 Web Project,不過 JSP 頁面總是需要用到 js、css、jpg、png 等等檔案。當你在撰寫頁面時將它們引入,但實際運行時卻發現這些檔案都出現該訊息: Http Status 404 - Not found.
發生上述錯誤訊息是因為 web.xml 裡面的設定,還記我們在一開始設定了 DispatcherServlet 對應的 url-pattern 為 " / ",如下圖:
因為我們設定 url-pattern 為 " / ",故連我們在 JSP 裡引進的 js、css 檔案都會符合 " / " 的情況進而透過 DispatcherServlet 將 Request 導向對應的 Controller,在這樣的情況下當然無法找到對應的檔案,因此 Server 端回應 404 錯誤訊息。
在這樣的情況下,首先必須思考我們 url-pattern 是否真的需要設定為 " / "?是否可以縮小 DispatcherServlet 處理 Request 的範圍。
當然 Spring 也有考慮到這個問題,在 3.0.? 版之後增加了取靜態資源的設定方法。我們先將靜態檔案擺放到自行設定的路徑,例如我增加了/WebContent/scripts/jquery-1.10.2.min.js ,參考下圖:
靜態檔案加入後,接著修改我們的 Spring 設定檔 ( 延續之前範例設定檔為 /WebContent/WEB-INF/mercury-servlet.xml ),如下圖:
從上面設定檔的內容可以發現,新增加了一個 <mvc:resources /> 標籤,其屬性的意思為該靜態資源對應 ( mapping ) 的路徑 /scripts/**,其靜態檔案實際位置 ( location ) 為 /scripts/,如此一來 Spring 就認得靜態資源的路徑,<mvc:resources /> 可以設定多個,因此你若有其他路徑也可以增加該標籤並加入你需要的 mapping 路徑與 location。除修改 Spring 設定檔之外, JSP 引進靜態資源的寫法也需要跟著修改,修改方式如下圖:
我們在 script src 的屬性部份改用 taglib 取得該靜態資源 <c:url value="" />,如此一來就可以正常的取得我們需要的 js 檔案。其他 Spring Framework 相關教學可以參考本篇整理。
熱門文章
-
相信大家有時等待測試、shell script 完成任務需要很長的時間,因此希望任務完成可以即時收到通知。在 Mac 上有 Growl 可以滿足這個需求,但 Growl 是收費軟體。所以我採用 terminal-notifier 工具發送 OS X 的通知 ( Notific...
-
Gitlab 為了讓使用者部署程式更方便,它提供了一個功能叫 Deploy Keys,使用者將 SSH Public Key 加入,之後不需要密碼就可以獲得程式庫 read-only 的權限,所以很適合運用在 CI 中。通常在 Unix-like 環境中將對應的 Key 與其使用...
-
TuxGuitar 是一個 Open Source 的編曲軟體,不僅擁有多個平台版本 ( Windows、Linux、Mac ),而且還可以讀取 Guitar Pro 的檔案。但也因為是免費的軟體,所以音源、效果沒有其他軟體來的多樣化。但對於練習、簡單編曲是絕對沒問題的。( 其他...
-
因常常使用 Mac Book Pro 開發,久而久之就習慣 MacVim 、Sublime Text 等軟體的顏色配置, 當然 Eclipse 也可以自己一步一步設定自己想要的顏色配置,但仍想要找找看是否有漂亮的 Color Themes,果然 Eclipse 的資源還是很豐富。...
-
在 Vim 中操作需要樹狀化顯示資料夾、檔案時可以使用 NERDTree 工具,而為了更加一步讓 Vim 操作起來更像與時俱進的 IDE,我們可以使用 NERDTree Tabs 來強化它。因此本篇將介紹如何在 Vim 中安裝、使用 NERDTree Tabs。( 其他 Linu...