Struts2環境搭建及實例解析

 

與struts1框架的使用同樣,struts2的環境搭建及使用一樣分爲如下幾個步驟:html

 

1.      引入jar包(這裏以struts2.2.3爲例),所需jar包有如下幾個:java

a)        struts2-core-2.2.3.jarweb

b)        xwork-core-2.2.3.jarapache

c)        commons-io-2.0.1.jar服務器

d)        commons-lang-2.5.jarapp

e)        commons-fileupload-1.2.2.jar框架

f)         freemarker-2.3.16.jarjsp

g)        ognl-3.0.1.jaride

h)        javassist-3.12.0.GA.jar(hibernate一樣須要)ui

 

2.      配置web.xml文件。全部的web項目都是以web.xml文件爲起點的,全部的起始配置都在這個文件中進行,而所謂的起始配置則是指在服務器啓動時所讀取的配置。好比咱們常常所用到的框架的配置,servlet的配置,filter的配置等信息。Struts2的web.xml文件與struts1的有所不一樣,使用struts1框架時用servlet標籤進行配置來關聯項目和框架,而使用struts2用的是filter標籤來關聯項目和框架。總的來講原理相同,都是經過映射來制定哪些類型的頁面須要交給框架去處理(在下文實例中會具體給出配置信息)。

 

3.      須要被框架核心類讀取的xml文件的配置。在struts1中這個xmL文件名稱爲struts-config,而struts2中該文件的名稱爲struts.xml。名字的差別可有可無,重要的是該文件中的配置信息有所不一樣,主要在於Struts-config中咱們定義了不少的ActionForm以及Action類,這些Action必須繼承ActionServlet抽象類,可是在struts2中已經沒有了ActionForm這個概念,原先ActionForm所承擔的職責已經被轉移到Action中,而且struts2中的Action支持徹底的POJO對象,固然也能夠繼承相應的ActionSupport類。

 

完成了上面的配置後接下來就是編寫咱們的Action類了,下面經過一個登錄實例來介紹struts2的使用。

 

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" 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>SSH5</display-name>
  
  <filter>
  	<filter-name>struts2</filter-name>
  	<filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class>
  </filter>
  
  <filter-mapping>
  	<filter-name>struts2</filter-name>
  	<url-pattern>/*</url-pattern>
  </filter-mapping>
</web-app>


Struts.xml配置信息以下:

 

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE struts PUBLIC
    "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
    "http://struts.apache.org/dtds/struts-2.0.dtd">

<struts>

   <constant name="struts.action.extension" value=","></constant>
  
   <package name="testLogin" namespace="/" extends="struts-default">	 
   		<action name="login" class="com.action.LoginAction">
   			<result name="success">/user.jsp</result>
   			<result name="error" type="redirect">/error.jsp</result>
   			<result name="checkError">/checkSession.jsp</result>
   			<interceptor-ref name="defaultStack"></interceptor-ref>
   		</action>
   </package>
 
</struts>


 

LoginAction類:

package com.action;

import com.entity.User;
import com.opensymphony.xwork2.ActionSupport;

public class LoginAction extends ActionSupport {

	private User user;

	public User getUser() {
		return user;
	}

	public void setUser(User user) {
		this.user = user;
	}

	@Override
	public String execute() throws Exception {
		if("admin".equals(user.getUsername()) && "admin".equals(user.getPassword())){
			System.out.println("登陸成功");
			return "success";
		}else{
			System.out.println("登陸失敗");
			return "error";
		}
	}
}


最後是jsp頁面代碼:

 

<%@ 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">
<title>Insert title here</title>
</head>
<body>
	<form action="login">
		登陸頁面<br>
		用戶名:<input name="user.username" type="text" ><br>
		密碼:<input name="user.password" tyep="password"><br>
		<input type="submit" value="登陸">
	</form>
</body>
</html>


上述登陸實例的執行過程爲當啓動TomCat的時候TomCat首先加載web.xml,根據web.xml中的配置信息由

 

 

org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter類讀取struts.xml中的信息,而後根據web.xml文件中規定的攔截文件路徑肯定哪些頁面將會交由struts框架進行處理,通常配置成/*,表示將對全部的頁面進行出攔截處理,而後根據jsp頁面中的提交路徑以及struts.xml文件中的配置信息肯定該頁面將提交給哪一個Action。當所提交的請求被Action處理後,將根據執行結果返回相應的字符串,根據返回值將決定具體的跳轉頁面。

相關文章
相關標籤/搜索