2016年5月23日 星期一

基本mvc架構 & 加入tiles

基本mvc架構
建立maven project (web-app)
project>右鍵>propeties>ProjectFacets>Runtimes>choose a runable server
【POM.xml】
<properties>
    <org.springframework-version>4.1.6.RELEASE</org.springframework-version>
    <jstl-version>1.2</jstl-version>
    <jstl-servlet-api-version>2.5</jstl-servlet-api-version>
</properties>

<dependencies>
    <!-- Spring -->
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-context-support</artifactId>
        <version>${org.springframework-version}</version>
    </dependency>
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-test</artifactId>
        <version>${org.springframework-version}</version>
    </dependency>
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-webmvc</artifactId>
        <version>${org.springframework-version}</version>
    </dependency>
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-tx</artifactId>
        <version>${org.springframework-version}</version>
    </dependency>

    <!-- Servlet -->
    <dependency>
        <groupId>javax.servlet</groupId>
        <artifactId>jstl</artifactId>
        <version>${jstl-version}</version>
    </dependency>
    <dependency>
        <groupId>javax.servlet</groupId>
        <artifactId>servlet-api</artifactId>
        <version>${jstl-servlet-api-version}</version>
    </dependency>
</dependencies>
【web.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"
xmlns:jsp="http://java.sun.com/xml/ns/javaee/jsp"
xsi:schemaLocation="http://java.sun.com/xml/ns/javaee
http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
version="2.5">

<servlet>
    <servlet-name>SpringServlet</servlet-name>
    <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
    <!-- if without "init-param", framework will try to load the application
    context from a file named [servlet-name]-servlet.xml in WEB-INF directory. -->
    <init-param>
        <param-name>contextConfigLocation</param-name>
        <param-value>/WEB-INF/config/SpringConfig.xml</param-value>
    </init-param>
    <load-on-startup>1</load-on-startup>
</servlet>

<servlet-mapping>
    <servlet-name>SpringServlet</servlet-name>
    <url-pattern>/</url-pattern>
</servlet-mapping>
</web-app>
webapp>WEB-INF>建立config>建立SpringConfig.xml

【SpringConfig.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:mvc="http://www.springframework.org/schema/mvc"
        xmlns:context="http://www.springframework.org/schema/context"
        xsi:schemaLocation="
            http://www.springframework.org/schema/beans
            http://www.springframework.org/schema/beans/spring-beans-4.1.xsd
            http://www.springframework.org/schema/mvc
            http://www.springframework.org/schema/mvc/spring-mvc-4.1.xsd
            http://www.springframework.org/schema/context
            http://www.springframework.org/schema/context/spring-context-4.1.xsd">
 
    <!-- basic -->
    <context:component-scan base-package="my.web" />

    <!-- basic -->
    <!-- view , the rules defined to resolve the view names -->
    <bean id="viewResolver"
        class="org.springframework.web.servlet.view.InternalResourceViewResolver">
        <!-- basic -->
        <property name="prefix" value="/WEB-INF/page/" />
        <property name="suffix" value=".jsp" />
    </bean>
</beans>
src>main>建立java>建立package(my.web.Controller)>建立MainController.java

【MainController.java】
package my.web.Controller;

import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping;

@Controller
public class MainController {
  @RequestMapping("hello")
  public String to_hello(String user, Model model) {
        model.addAttribute("user", user);
  return "hello";
  }
}
測試用的hello.jsp
放置於WEB-INF/page/目錄下
<%@ page contentType = "text/html;charset=UTF-8" %>
<html>
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
    <title>Hello page</title>
</head>
<body>
    <div>
        <h1>Hello ${user}!!</h1>
    </div>
</body>
</html>
其他:
在專案上右鍵>MAVEN>update project
如果無法升級至Dynamic Web Module 2.5
在專案上右鍵>properties>project facets把Dynamic Web Module 取消勾選,再update一次


將eclipse的window>preference>General>Workspace>Text file encoding改為UTF-8




加入tiles
【POM.xml】

<properties>
    <tiles-version>3.0.5</tiles-version>
</properties>

<dependencies>
    <!-- Tiles basic -->
    <dependency>
        <groupId>org.apache.tiles</groupId>
        <artifactId>tiles-jsp</artifactId>
        <version>${tiles-version}</version>
    </dependency>
    <dependency>
        <groupId>org.apache.tiles</groupId>
        <artifactId>tiles-servlet</artifactId>
        <version>${tiles-version}</version>
    </dependency>
    <!-- Tiles others -->
    <dependency>
        <groupId>org.apache.tiles</groupId>
        <artifactId>tiles-template</artifactId>
        <version>${tiles-version}</version>
    </dependency>
    <dependency>
        <groupId>org.apache.tiles</groupId>
        <artifactId>tiles-el</artifactId>
        <version>${tiles-version}</version>
    </dependency>
</dependencies>
【SpringConfig.xml】

更改 viewResolver.order:
<!-- 因為使用了其他的ViewResolver(ex:tiles),因此必須設定解析順序 -->
<property name="order" value="#{tilesViewResolver.order+1}" />

加入:
<!-- Tiles View -->
<bean id="tilesViewResolver"
class="org.springframework.web.servlet.view.UrlBasedViewResolver">
<property name="viewClass"
        value="org.springframework.web.servlet.view.tiles3.TilesView" />
<property name="order" value="1" />
</bean>
<!-- 加載tiles配置文件 -->
<bean id="tilesConfigurer"
class="org.springframework.web.servlet.view.tiles3.TilesConfigurer">
<property name="definitions">
<list> <!-- 設定檔路徑 -->
<value>/WEB-INF/config/defaultTemplate.xml</value>
<value>/WEB-INF/config/tiles-definitions.xml</value>
</list>
  </property>
<!-- 定義preparerFactory的種類(有2種: SimpleSpring & SpringBean) -->
<property name="preparerFactoryClass"
value="org.springframework.web.servlet.view.tiles3.SimpleSpringPreparerFactory" />
</bean>
WEB-INF>config>建立tiles-definitions.xml

【tiles-definitions.xml】

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

<!-- XML reading definitions for tiles -->
<!DOCTYPE tiles-definitions PUBLIC
"-//Apache Software Foundation//DTD Tiles Configuration 3.0//EN"
"http://tiles.apache.org/dtds/tiles-config_3_0.dtd">

<tiles-definitions>

  <definition name="default" extends="defaultTemplate">
  </definition>

  <definition name="hello" extends="defaultTemplate">
  <put-attribute name="content" value="/WEB-INF/page/hello.jsp" />
  </definition>

</tiles-definitions>
WEB-INF>config>建立defaultTemplate.xml

【defaultTemplate.xml】

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

<!DOCTYPE tiles-definitions PUBLIC
        "-//Apache Software Foundation//DTD Tiles Configuration 3.0//EN"
        "http://tiles.apache.org/dtds/tiles-config_3_0.dtd">

<tiles-definitions>
  <definition name="defaultTemplate"
        template="/WEB-INF/page/defaultview/defaultLayout.jsp">
  <!-- put-attribute name="navigation_bar" value="/WEB-INF/page/navigation_bar.jsp" / -->
  <put-attribute name="header" value="/WEB-INF/page/defaultview/defaultHeader.jsp" />
  <put-attribute name="content" value="/WEB-INF/page/defaultview/defaultContent.jsp"/>

  <!-- default CSS -->
  <!-- put-list-attribute name="csssList" cascade="true">
  <add-attribute value="styles/datepicker.css"/>
  </put-list-attribute -->

  <!-- default Script -->
    <!-- put-list-attribute name="scriptsList" cascade="true" >
  <add-attribute value="script/jquery.js" / >
  </put-list-attribute -->
  </definition>
</tiles-definitions>
WEB-INF>page>建立defaultview>建立defaultLayout.jsp/defaultHeader.jsp/defaultContent.jsp

【defaultLayout.jsp】
<%@ taglib uri="http://tiles.apache.org/tags-tiles" prefix="tiles"%>
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
</head>
<body>
<tiles:insertAttribute name="header" />
<tiles:insertAttribute name="content" />
</body>
</html>

【defaultHeader.jsp】
<%@ page contentType = "text/html;charset=UTF-8" %>
<div>
<h1>Default Header</h1>
</div>

【defaultContent.jsp】
<%@ page contentType = "text/html;charset=UTF-8" %>
<div>
<h1>Default Content</h1>
</div>
【hello.jsp】修改為:
<%@ page contentType = "text/html;charset=UTF-8" %>
<div>
    <h1>Hello ${user}!!</h1>
    <br />
    <a href="hello_Tiles">helloTiles.html</a>
</div>

沒有留言:

張貼留言