`
reverocean
  • 浏览: 192795 次
  • 性别: Icon_minigender_1
社区版块
存档分类
最新评论

Spring mvc3 tiles

 
阅读更多

1.创建项目

eclipse里选择新建Maven Project,然后选择mave-archetype-webappArchetype,这样就会创建一个Eclipse WTP能识别的Web项目,能够Run  on server

2.修改POM

                为项目加入相关的dependency,包括Springtiles等。

2.1添加Spring的依赖

            <dependency>

                  <groupId>org.springframework</groupId>

                  <artifactId>spring-webmvc</artifactId>

                  <version>${org.springframework.version}</version>

                  <scope>compile</scope>

            </dependency>  

                这里只添加spring-webmvc的依赖,Maven会根据spring-webmvc包里的pom找到他需要的其他相关jar包的依赖,包括spring-core.jarspring-bean.jar等。

2.2添加Tiles的依赖

                Apache Tiles的官方网站上的Downloadhttp://tiles.apache.org/download.html)页面里有如何在Maven里加Tiles的依赖。

<!--[if !supportLists]-->·         <!--[endif]--> The complete Tiles dependency with all supported technologies

                            <dependency>

                        <groupId>org.apache.tiles</groupId>

                        <artifactId>tiles-extras</artifactId>

                        <version>2.2.2</version>

      </dependency>

<!--[if !supportLists]-->·         <!--[endif]-->The basic Tiles dependency with only servlet support

                  <dependency>

                        <groupId>org.apache.tiles</groupId>

                        <artifactId>tiles-servlet</artifactId>

                        <version>2.2.2</version>

      </dependency>

<!--[if !supportLists]-->·         <!--[endif]-->Tiles JSP support

                  <dependency>

                        <groupId>org.apache.tiles</groupId>

                        <artifactId>tiles-jsp</artifactId>

                        <version>2.2.2</version>

      </dependency>

 

2.3添加jstl依赖

                                <dependency>

                  <groupId>javax.servlet</groupId>

                  <artifactId>jstl</artifactId>

                  <version>1.2</version>

                  <scope>runtime</scope>

            </dependency>

2.4添加Servlet相关的Provided依赖

            <dependency>

                  <groupId>javax.servlet</groupId>

                  <artifactId>servlet-api</artifactId>

                  <version>2.5</version>

                  <type>jar</type>

                  <scope>provided</scope>

            </dependency>

            <dependency>

                  <groupId>javax.servlet.jsp</groupId>

                  <artifactId>jsp-api</artifactId>

                  <version>2.1</version>

                  <type>jar</type>

                  <scope>provided</scope>

            </dependency>

3.修改web.xml

<?xml version="1.0" encoding="UTF-8"?>

<web-app version="2.5" xmlns="http://java.sun.com/xml/ns/javaee"

      xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"

      xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd">

 

      <display-name>Archetype Created Web Application</display-name>

      <servlet>

            <servlet-name>tiles</servlet-name>

            <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>

            <load-on-startup>1</load-on-startup>

      </servlet>

 

      <servlet-mapping>

            <servlet-name>tiles</servlet-name>

            <url-pattern>/</url-pattern>

      </servlet-mapping>

</web-app>

这里servlet-name的值是tiles,并且没有给DispatcherServlet配置contextConfigLocation(可以通过这个值指定spring的配置文件),Spring MVC会从WEB-INF里去找tiles-servlet.xmlspring的配置文件。

4.tiles-servlet.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:aop="http://www.springframework.org/schema/aop"

      xmlns:task="http://www.springframework.org/schema/task"

      xmlns:context="http://www.springframework.org/schema/context"

      xmlns:mvc="http://www.springframework.org/schema/mvc"

      xmlns:tx="http://www.springframework.org/schema/tx"

      xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd

            http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-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

            http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.0.xsd

http://www.springframework.org/schema/task

http://www.springframework.org/schema/task/spring-task-3.0.xsd "

      default-autowire="byName"

      default-lazy-init="false">

      <!-- 当用户访问在webapp文件夹下的静态资源的时候,通过下面的配置直接访问,而不去找Controller -->

      <mvc:resources

            mapping="/resources/**"

            location="/resources/" />

      <!-- Spring MVC添加annotation-driven,该配置包括了对JSR-303 Validationmessage conversionfiled

            formatting -->

      <mvc:annotation-driven />

      <!-- 配置Spring扫描Controller存放的包路径 -->

      <context:component-scan

            base-package="com.rever.tiles.mvc" />

      <!-- 配置Spring MVC的视图,从WEB-INF/views文件夹下去找对应的视图 -->

      <!-- p:prefix="/WEB-INF/jsp/" p:suffix=".jsp" p:order="1" -->

      <bean

            id="viewResolver"

            class="org.springframework.web.servlet.view.InternalResourceViewResolver">

            <!-- 为了使用JSTL Tag修改默认的viewClass属性 -->

            <property

                  name="viewClass"

                  value="org.springframework.web.servlet.view.JstlView" />

            <property

                  name="prefix"

                  value="/WEB-INF/views/" />

            <property

                  name="suffix"

                  value=".jsp"></property>

            <property

                  name="order"

                  value="1"></property>

      </bean>

      <!-- Convenience subclass of UrlBasedViewResolver that supports TilesView

            (i.e. Tiles definitions) and custom subclasses of it. -->

      <!-- Don't forget to set the order if you declared other ViewResolvers -->

      <!-- See http://static.springsource.org/spring/docs/3.0.x/javadoc-api/org/springframework/web/servlet/view/tiles2/TilesViewResolver.html -->

     

      <bean

            id="tilesviewResolver"

            class="org.springframework.web.servlet.view.tiles2.TilesViewResolver">

            <property

                  name="order"

                  value="0"></property>

      </bean>

<!-- Helper class to configure Tiles 2.x for the Spring Framework -->

      <!-- See http://static.springsource.org/spring/docs/3.0.x/javadoc-api/org/springframework/web/servlet/view/tiles2/TilesConfigurer.html -->

      <!-- The actual tiles templates are in the tiles-definitions.xml -->

     

      <bean

            id="tilesConfigurer"

            class="org.springframework.web.servlet.view.tiles2.TilesConfigurer">

            <property

                  name="definitions">

                  <list>

                        <value>/WEB-INF/tiles-definitions.xml</value>

                  </list>

            </property>

      </bean>

</beans>

5. tiles-definitions.xml

                <?xml version="1.0" encoding="UTF-8"?>

<!DOCTYPE tiles-definitions PUBLIC

       "-//Apache Software Foundation//DTD Tiles Configuration 2.0//EN"

       "http://tiles.apache.org/dtds/tiles-config_2_0.dtd">

<tiles-definitions>

 

      <!-- We declare a new template named template-main. This template is used

            for displaying the main page. It has 4 attributes. These attributes are placeholder

            for our contents For each attribute, we have assigned a corresponding JSP -->

      <definition

            name="template-main"

            template="/WEB-INF/views/layouts/main.jsp">

            <put-attribute

                  name="banner-content"

                  value="/WEB-INF/views/sections/banner.jsp" />

            <put-attribute

                  name="title-content"

                  value="Pet Type" />

            <put-attribute

                  name="primary-content"

                  value="" />

            <put-attribute

                  name="footer-content"

                  value="/WEB-INF/views/sections/footer.jsp" />

      </definition>

 

      <!-- We declare a new template named template-detail. This template is used

            for displaying details of an item. It has 5 attributes. These attributes

            are placeholder for our contents For each attribute, we have assigned a corresponding

            JSP -->

      <definition

            name="template-detail"

            template="/WEB-INF/views/layouts/details.jsp">

            <put-attribute

                  name="banner-content"

                  value="/WEB-INF/views/sections/banner.jsp" />

            <put-attribute

                  name="title-content"

                  value="Pet Type" />

            <put-attribute

                  name="subtitle-content"

                  value="" />

            <put-attribute

                  name="primary-content"

                  value="" />

            <put-attribute

                  name="footer-content"

                  value="/WEB-INF/views/sections/footer.jsp" />

      </definition>

 

      <!-- Concrete page. To use this page, your controller must return the name

            "pet-tiles" -->

      <definition

            name="pet-tiles"

            extends="template-main">

            <put-attribute

                  name="primary-content"

                  value="/WEB-INF/views/contents/pets.jsp" />

      </definition>

 

      <!-- Concrete page. To use this page, your controller must return the name

            "dog-tiles" -->

      <definition

            name="dog-tiles"

            extends="template-detail">

            <put-attribute

                  name="subtitle-content"

                  value="Canines" />

            <put-attribute

                  name="primary-content"

                  value="/WEB-INF/views/contents/dogs.jsp" />

      </definition>

 

      <!-- Concrete page. To use this page, your controller must return the name

            "cat-tiles" -->

      <definition

            name="cat-tiles"

            extends="template-detail">

            <put-attribute

                  name="subtitle-content"

                  value="Felines" />

            <put-attribute

                  name="primary-content"

                  value="/WEB-INF/views/contents/cats.jsp" />

      </definition>

 

</tiles-definitions>

                tiles的配置文件里定义了两个模板(template-maintemplate-detail),template-main模板的模板jsp文件是layouts/main.jsp,其内容如下:

<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%>

<%@ taglib uri="http://tiles.apache.org/tags-tiles" prefix="tiles"%>

<%@ page language="java" contentType="text/html; charset=UTF-8"

      pageEncoding="UTF-8"%>

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">

<html>

<head>

<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">

 

<style type="text/css">

body {

      background: #555;

      width: 400px;

      border: 1px solid #fff;

      padding: 0px;

}

 

div {

      padding: 5px;

      margin: 0px;

}

 

h1,h2,p {

      padding: 0px;

      margin: 0px;

}

 

#banner-style {

      background: #3B3E37;

}

 

#title-style {

      background: #665845;

}

 

#subtitle-style {

      background: #9F8158;

}

 

#primary-style {

      background: #EBC785;

}

 

#footer-style {

      background: #733027;

}

</style>

 

<title>Insert title here</title>

</head>

<body style="background: #555;">

 

      <div id="banner-style">

            <tiles:insertAttribute name="banner-content" />

      </div>

      <div id="title-style">

            <h2>

                  <tiles:insertAttribute name="title-content" />

            </h2>

      </div>

      <div id="primary-style">

            <tiles:insertAttribute name="primary-content" />

      </div>

      <div id="footer-style">

            <tiles:insertAttribute name="footer-content" />

      </div>

</body>

</html>

这里定义了banner-content,title-contentprimary-contentfooter-content几个大块内容,这些和tiles配置文件里的template-main模板里的元素对应。

            <put-attribute

                  name="banner-content"

                  value="/WEB-INF/views/sections/banner.jsp" />

            <put-attribute

                  name="title-content"

                  value="Pet Type" />

            <put-attribute

                  name="primary-content"

                  value="" />

            <put-attribute

                  name="footer-content"

                  value="/WEB-INF/views/sections/footer.jsp" />

从上面的代码中可以看出main.jsp中的banner-content使用sections/banner.jsp文件(应该是使用include)。title-content在这里就写死了,是Pet Type,当然子模板也可以覆盖这个属性。Primary-content这里没有设置内容,需要子模板提供相应的数据。Footer-content使用sections/footer.jsp文件。

子模板pet-tiles就继承了上面template-main模板,其内容如下:

<definition

            name="pet-tiles"

            extends="template-main">

            <put-attribute

                  name="primary-content"

                  value="/WEB-INF/views/contents/pets.jsp" />

      </definition>

可以看出,子模板中没有指定banner-contenttitle-contentfooter-content,只是指定了primary-content,使用contents/pets.jsp文件。

6.Controller

                Controller里没有什么好说的,唯一需要说明的是,在controller的方法里返回的视图名不是真正对应的jsp名,要对应tiles配置文件里的名字。比如上面的pet-tiles,而不能返回pets

 

Tiles+Spring MVC相关的内容从http://krams915.blogspot.com/2010/12/spring-mvc-3-tiles-2-integration.html里看的,可以去这里查找原文章。

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics