剛開始搞spring mvc和freemarker,遇到了很多問題,首先是導入靜態文件,記錄一下,但願能幫助親們少走彎路吧。 本章不介紹freemarker的神馬複雜用法(由於我也不會),也不講解spring mvc的種種,僅僅關注兩者結合後靜態文件的導入問題,和最初的一些配置。
###>文件結構一覽javascript
###>jar包一覽css
###>web.xmlhtml
關鍵一句話,就是springmvc的那個servlet,由於要用RESTFul風格,因此攔截/,而且讓它去讀springMVC來初始化(java /src 根路徑)。java
<!-- lang: xml --> <?xml version="1.0" encoding="UTF-8"?> <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" id="WebApp_ID" version="2.5"> <display-name>justforfun</display-name> <welcome-file-list> <welcome-file>index.html</welcome-file> </welcome-file-list> <servlet> <servlet-name>springMVC</servlet-name> <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> <init-param> <param-name>contextConfigLocation</param-name> <param-value>classpath*:/springMVC.xml</param-value> </init-param> <load-on-startup>1</load-on-startup> </servlet> <servlet-mapping> <servlet-name>springMVC</servlet-name> <url-pattern>/</url-pattern> </servlet-mapping>
</web-app>jquery
###>springMVC.xmllinux
配置ftl config和viewResolver都是網上找的,直接copy過去,關鍵是mvc:resources,後面的location注意要放到能夠被訪問的地方(tomcat中WEB-INF下的東東貌似別人是訪問不到的),spring的問檔中說能夠放在跟目錄下或者神馬著名的可被訪問的目錄(好像應該這麼翻譯)META-INF.web
<!-- lang: xml --> <?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:tx="http://www.springframework.org/schema/tx" xmlns:context="http://www.springframework.org/schema/context" xmlns:mvc="http://www.springframework.org/schema/mvc" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.0.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.0.xsd http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-3.0.xsd"> <!-- 自動掃描的包名 --> <context:component-scan base-package="com.app,com.core,JUnit4"></context:component-scan> <!-- 默認的註解映射的支持 --> <mvc:annotation-driven /> <!-- freemarker config --> <bean id="freemarkerConfig" class="org.springframework.web.servlet.view.freemarker.FreeMarkerConfigurer"> <property name="templateLoaderPath" value="/WEB-INF/ftl/" /> </bean> <!-- View resolvers can also be configured with ResourceBundles or XML files. If you need different view resolving based on Locale, you have to use the resource bundle resolver. --> <bean id="viewResolver" class="org.springframework.web.servlet.view.freemarker.FreeMarkerViewResolver"> <property name="cache" value="true" /> <property name="prefix" value="" /> <property name="suffix" value=".ftl" /> <property name="contentType" value="text/html; charset=UTF-8"/> </bean> <!-- 攔截器 --> <!-- <mvc:interceptors> <bean class="com.core.mvc.MyInteceptor" /> </mvc:interceptors> --> <!-- 對靜態資源文件的訪問 方案一 (二選一) --> <!-- <mvc:default-servlet-handler /> --> <!-- 對靜態資源文件的訪問 方案二 (二選一) --> <mvc:resources mapping="/images/**" location="/META-INF/resources/images/" cache-period="31556926" /> <mvc:resources mapping="/js/**" location="/META-INF/resources/js/" cache-period="31556926" /> <mvc:resources mapping="/css/**" location="/META-INF/resources/css/" cache-period="31556926" />
</beans>spring
###>ftl文件vim
導入spring.ftl是爲了得到一個路徑,@s.url,這個東東會自動加上你工程的名字,例如<@s.url '/css/default.css'/>,會變成justforfun/css/default.css,千萬注意!!!
script必定不能寫成<script 某某某 />,應該寫成<script 某某某></script>
,要否則這行後面的東西在html裏面都解析不到了,被這個糾結了很久,不知道爲神馬,但願大牛看到能告知告知。windows
<!-- lang: html --> <#import "spring.ftl" as s /> <!DOCTYPE> <html> <head> <title> 首頁 </title> <link rel="stylesheet" type="text/css" href="<@s.url '/css/default.css'/>"/> <script type="text/javascript" src="<@s.url '/js/jquery.min.js'/>"> </script> </head> <body> <h1> 首頁的試煉 </h1> <div> bingo! <img src = "<@s.url '/images/img1.jpg'/>"/> </div> </body>
</html>
###>spring的controller
這個僅僅返回index就行了。
<!-- lang: java --> package com.app.controller; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestMethod; @Controller @RequestMapping("/") public class IndexController { @RequestMapping(method=RequestMethod.GET) public String index(){ return "index"; }
}
###>最終效果
能夠見到,圖片,css,js,都沒問題,並且由於springMVC裏面設置了UTF-8,因此顯示的是中文而不是亂碼。
####ps,加強你的效率vimer 找到了一個老哥配置的gvim,很是不錯,在eclipse裏面能夠用viplugin這個插件,在環境變量裏面加入vim的路徑,:vim便可直接啓用vim編輯,美中不足的是沒有加上command-T這個插件,由於用ruby,windows下各類不成功,惋惜。linux下推薦janus這個vim插件管理器很好很強大,並且command-T也默認安裝了,:help janus有很大驚喜 另外,用zsh吧,好好配置一下,它的tab功能比bash強好多。 http://www.oschina.net/code/snippet_574132_13357
###pps 爲何上面圖片不顯示???