zoukankan      html  css  js  c++  java
  • Struts2环境搭建及实例解析

    与struts1框架的使用一样,struts2的环境搭建及使用同样分为以下几个步骤:

    1.      引入jar包(这里以struts2.2.3为例),所需jar包有以下几个:

    a)        struts2-core-2.2.3.jar

    b)        xwork-core-2.2.3.jar

    c)        commons-io-2.0.1.jar

    d)        commons-lang-2.5.jar

    e)        commons-fileupload-1.2.2.jar

    f)         freemarker-2.3.16.jar

    g)        ognl-3.0.1.jar

    h)        javassist-3.12.0.GA.jar(hibernate同样需要)

     

    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处理后,将根据执行结果返回相应的字符串,根据返回值将决定具体的跳转页面。

  • 相关阅读:
    Why use strong named assemblies?
    Dependency Walker
    “等一下,我碰!”——常见的2D碰撞检测
    MOBA游戏的网络同步技术
    VS2017如何配置openGL环境
    UE4关于Oculus Rift (VR)开发忠告
    UE4 的json读写方式
    Blueprint 编译概述
    UE4编码规范
    Unreal Enginer4特性介绍
  • 原文地址:https://www.cnblogs.com/keanuyaoo/p/3423952.html
Copyright © 2011-2022 走看看