SpringMVC4+thymeleaf3的一个简单实例(篇二:springMVC与thymeleaf的整合)

延续前篇内容。

开始之前,我们首先要准备以下12个jar文件:
spring-aop-4.3.3.RELEASE.jar
spring-beans-4.3.3.RELEASE.jar
spring-context-4.3.3.RELEASE.jar
spring-core-4.3.3.RELEASE.jar
spring-expression-4.3.3.RELEASE.jar
spring-web-4.3.3.RELEASE.jar
spring-webmvc-4.3.3.RELEASE.jar
thymeleaf-3.0.2.RELEASE.jar
thymeleaf-spring4-3.0.2.RELEASE.jar
attoparser-2.0.1.RELEASE.jar
slf4j-api-1.6.6.jar
commons-logging-1.2.jar

它们来自于spring-framework-4.3.3.RELEASE-dist.zip,thymeleaf-3.0.2.RELEASE-dist.zip,commons-logging-1.2-bin.tar.gz,请从官网下载
spring: http://repo.spring.io/release/org/springframework/spring/
thymeleaf: https://dl.bintray.com/thymeleaf/downloads/thymeleaf/
common log: http://commons.apache.org/proper/commons-logging/download_logging.cgi

1: 把12个jar文件拷贝到WEB-INF的lib目录下(eclipse支持鼠标拖拽),并添加到build path下:

查看项目所在硬盘路径:鼠标右击项目 zoo,下拉菜单->Properties,弹出对话框即可查看:

 

2: 修改web.xml文件,添加spring的dispatcherServlet;指定spring的配置文件:classpath下的com/xmlconfig/spring-mvc.xml文件;过滤所有以.html结尾的请求。

load-on-startup参数设置为1,表示web应用启动的时候就会实例化这个servlet,数值必须是整数,如果是负整数或者没有设置,那么web容器自己会选择它的初始化时机,如果是大于等于0的整数,那么这个servlet会在web应用启动的时候初始化,并且数字越小越先被初始化,对于值相等的servlet,web容器会选择初始化顺序。

 内容如下:

 1 <?xml version="1.0" encoding="UTF-8"?>  
 2 <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee"   
 3 xsi:schemaLocation="http://java.sun.com/xml/ns/javaee   
 4 http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd" id="WebApp_ID" version="3.0">  
 5   <display-name>zoo</display-name>  
 6   
 7   <servlet>  
 8     <servlet-name>springMVC</servlet-name>  
 9     <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>  
10     <init-param>  
11       <param-name>contextConfigLocation</param-name>  
12       <param-value>classpath:com/xmlconfig/spring-mvc.xml</param-value>  
13     </init-param>  
14     <load-on-startup>1</load-on-startup>  
15   </servlet>  
16   
17   <servlet-mapping>  
18     <servlet-name>springMVC</servlet-name>  
19     <url-pattern>*.html</url-pattern>  
20   </servlet-mapping>  
21     
22   <welcome-file-list>  
23     <welcome-file>index.html</welcome-file>  
24     <welcome-file>index.htm</welcome-file>  
25     <welcome-file>index.jsp</welcome-file>  
26     <welcome-file>default.html</welcome-file>  
27     <welcome-file>default.htm</welcome-file>  
28     <welcome-file>default.jsp</welcome-file>  
29   </welcome-file-list>  
30 </web-app> 

 

3: 在src目录下新建package:com.xmlconfig(其实就是硬盘里的文件夹src/com/config),并在这个package下面新建xml文件:
spring-mvc.xml,内容为:

 1 <?xml version="1.0" encoding="UTF-8"?>  
 2   
 3 <beans xmlns="http://www.springframework.org/schema/beans"  
 4     xmlns:mvc="http://www.springframework.org/schema/mvc"  
 5     xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  
 6     xmlns:context="http://www.springframework.org/schema/context"  
 7     xsi:schemaLocation="http://www.springframework.org/schema/beans  
 8         http://www.springframework.org/schema/beans/spring-beans.xsd  
 9         http://www.springframework.org/schema/context  
10         http://www.springframework.org/schema/context/spring-context.xsd  
11         http://www.springframework.org/schema/mvc  
12         http://www.springframework.org/schema/mvc/spring-mvc.xsd">  
13     
14   
15   <!-- spring扫描com.zoo.web.controller下面所有带注解的类 -->  
16   
17   <context:component-scan base-package="com.zoo.web.controller"/>  
18   <!-- 这个标签表示使用注解来驱动 -->  
19   <mvc:annotation-driven/>  
20   
21   <!-- 使用thymeleaf解析 -->  
22   <bean id="templateResolver"  
23         class="org.thymeleaf.spring4.templateresolver.SpringResourceTemplateResolver">  
24     <property name="prefix" value="/WEB-INF/pages/" />  
25     <property name="suffix" value=".html" />  
26     <property name="templateMode" value="HTML" />  
27     <property name="cacheable" value="false" />  
28   </bean>  
29       
30   <bean id="templateEngine"  
31         class="org.thymeleaf.spring4.SpringTemplateEngine">  
32     <property name="templateResolver" ref="templateResolver" />  
33   </bean>  
34   
35   <bean class="org.thymeleaf.spring4.view.ThymeleafViewResolver">  
36     <property name="templateEngine" ref="templateEngine" />  
37   </bean>  
38   
39 </beans> 

解释:

prefix,用于指定template所在目录;

suffix,过滤请求,这里是处理所有以.html结尾的请求;

templateMode,设置为html;

cacheable,是否缓存页面,开发时设置为false,这样就可以在不重启服务器的情况下刷新页面即可查看修改效果;

 

4: 在src目录下添加package:com.zoo.web.controller,并新建类ZooController,其内容是:

    package com.zoo.web.controller;  
      
    import org.springframework.stereotype.Controller;  
    import org.springframework.web.bind.annotation.RequestMapping;  
    import org.springframework.web.bind.annotation.RequestMethod;  
      
    @Controller  
    public class ZooController {  
      
        @RequestMapping(path = "/list", method = RequestMethod.GET)  
        public String showZooList(){  
            return "zoolist";  
        }  
          
    }  

类上面的注解@Controller表示这个类是一个Controller类型的组件,spring根据这个注解就可以扫描到并将其注册到容器中,在有http请求过来的时候spring会根据url找到匹配的controller并执行对应的方法。
@RequestMapping注解的是方法showZooList(),当浏览器访问http://localhost:8080/zoo/list.html地址时就会调用此函数。函数返回的是个字符串,这个字符串对应的是/WEB-INF/pages/下的文件名,记住是不带扩展名的,这个是在spring-mvc.xml中<property name="prefix" value="/WEB-INF/pages/" />配置的。其中method=RequestMethod.GET表示只响应get请求,如果同样的url换成post请求就不会触发这个方法。

5: 在WEB-INF下新建文件夹pages,并在pages里新建文件zoolist.html,添加一些静态数据,内容为:

 1 <!DOCTYPE html>  
 2 <html>  
 3 <head>  
 4 <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">  
 5 <title>zoo list</title>  
 6 </head>  
 7 <body>  
 8     <table border="1">    
 9       <tr>  
10         <th>序号</th>  
11         <th>动物名称</th>    
12         <th>数量</th>   
13         <th>备注</th>  
14       </tr>  
15       <tr>  
16         <td>1</td>  
17         <td>大马猴</td>  
18         <td>10</td>  
19         <td>机灵古怪,俏皮活泼</td>  
20       </tr>  
21       <tr>  
22         <td>2</td>  
23         <td>大熊猫</td>  
24         <td>80</td>  
25         <td>体型笨重,喜欢吃竹子</td>  
26       </tr>  
27       <tr>  
28         <td>3</td>  
29         <td>澳洲羊驼</td>  
30         <td>13</td>  
31         <td>长相奇特,大国人俗称其草泥马</td>  
32       </tr>  
33       <tr>  
34         <td>4</td>  
35         <td>峨眉山猴</td>  
36         <td>90</td>  
37         <td>不怕人,有时候发贱抢游客面包吃</td>  
38       </tr>  
39     </table>  
40 </body>  
41 </html> 

到此为止所需的材料基本上就全都整好啦,现在我们的项目结构大概是这个样子

让我们启动tomcat试一试吧!

启动完成后看看你的Console是不是一切正常,如果有出错信息,请自行排查。

打开浏览器输入http://localhost:8080/zoo/list.html

哎呀!怎么都是问号呀!?
别担心,小问题,我们只需在spring-mvc.xml中添加一句话就ok啦拉拉,
把<property name="characterEncoding" value="UTF-8"/>加进去,放在哪里呀?请使劲看:

 1 <?xml version="1.0" encoding="UTF-8"?>  
 2 <beans xmlns="http://www.springframework.org/schema/beans"  
 3     xmlns:mvc="http://www.springframework.org/schema/mvc"  
 4     xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  
 5     xmlns:context="http://www.springframework.org/schema/context"  
 6     xsi:schemaLocation="http://www.springframework.org/schema/beans  
 7         http://www.springframework.org/schema/beans/spring-beans.xsd  
 8         http://www.springframework.org/schema/context  
 9         http://www.springframework.org/schema/context/spring-context.xsd  
10         http://www.springframework.org/schema/mvc  
11         http://www.springframework.org/schema/mvc/spring-mvc.xsd">  
12           
13   <context:component-scan base-package="com.zoo.web.controller"/>  
14   <mvc:annotation-driven/>  
15   
16   <!-- 使用thymeleaf解析 -->  
17   <bean id="templateResolver"  
18         class="org.thymeleaf.spring4.templateresolver.SpringResourceTemplateResolver">  
19     <property name="prefix" value="/WEB-INF/pages/" />  
20     <property name="suffix" value=".html" />  
21     <property name="templateMode" value="HTML" />  
22     <property name="cacheable" value="false" />  
23   </bean>  
24       
25   <bean id="templateEngine"  
26         class="org.thymeleaf.spring4.SpringTemplateEngine">  
27     <property name="templateResolver" ref="templateResolver" />  
28   </bean>  
29   
30   <bean class="org.thymeleaf.spring4.view.ThymeleafViewResolver">  
31     <property name="templateEngine" ref="templateEngine" />  
32     <!--解决中文乱码-->  
33     <property name="characterEncoding" value="UTF-8"/>  
34   </bean>  
35   
36 </beans> 

完成后记得重新启动tomcat,再用浏览器看一看:

哇,正常了,终于看到大马猴和草泥马啦拉拉!

等一等,我们是不是忘记了什么?对了,我们再访问一下首页http://localhost:8080/zoo看看

咿呀呀,搞什么飞机,怎么出错啦,还是404,怎么找不到页面啦,让阿拉想想怎么解决......

好,有了,同样在spring-mvc.xml中添加一句话就ok,
把<mvc:default-servlet-handler />加进去就能解决。这句话怎么这么列害!为什么呢?
让我们想一想整个流程,当http://localhost:8080/zoo这个请求来到tomcat server时,实际上请求的是http://localhost:8080/zoo/index.html或者http://localhost:8080/zoo/default.jsp,总之是wellcome-file-list中的某个页面,可实际上在我们的应用中没有哪个类的哪个方法来响应/index.html或者default.jsp等,所以这句话的意思就是在这条路走不通的情况下使用默认servlet来处理,这个标签对应的是
org.springframework.web.servlet.resource.DefaultServletHttpRequestHandler 这个handler,它转而调用当前web容器默认的servlet,让当前默认servlet来处里。

最后的内容如下:

 1 <?xml version="1.0" encoding="UTF-8"?>  
 2 <beans xmlns="http://www.springframework.org/schema/beans"  
 3     xmlns:mvc="http://www.springframework.org/schema/mvc"  
 4     xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  
 5     xmlns:context="http://www.springframework.org/schema/context"  
 6     xsi:schemaLocation="http://www.springframework.org/schema/beans  
 7         http://www.springframework.org/schema/beans/spring-beans.xsd  
 8         http://www.springframework.org/schema/context  
 9         http://www.springframework.org/schema/context/spring-context.xsd  
10         http://www.springframework.org/schema/mvc  
11         http://www.springframework.org/schema/mvc/spring-mvc.xsd">  
12           
13   <context:component-scan base-package="com.zoo.web.controller"/>  
14   <mvc:annotation-driven/>  
15   <!-- 默认servlet -->  
16   <mvc:default-servlet-handler />  
17     
18   <!-- 使用thymeleaf解析 -->  
19   <bean id="templateResolver"  
20         class="org.thymeleaf.spring4.templateresolver.SpringResourceTemplateResolver">  
21     <property name="prefix" value="/WEB-INF/pages/" />  
22     <property name="suffix" value=".html" />  
23     <property name="templateMode" value="HTML" />  
24     <property name="cacheable" value="false" />  
25   </bean>  
26       
27   <bean id="templateEngine"  
28         class="org.thymeleaf.spring4.SpringTemplateEngine">  
29     <property name="templateResolver" ref="templateResolver" />  
30   </bean>  
31   
32   <bean class="org.thymeleaf.spring4.view.ThymeleafViewResolver">  
33     <property name="templateEngine" ref="templateEngine" />  
34     <!--解决中文乱码-->  
35     <property name="characterEncoding" value="UTF-8"/>  
36   </bean>  
37   
38 </beans>

重启服务器再试试看,是不是好了呢。

本篇的内容到此也就结束了,下一篇介绍页面参数获取。

 

END.

 

posted on 2016-11-23 15:27  水手009  阅读(15747)  评论(4编辑  收藏  举报