zoukankan      html  css  js  c++  java
  • Struts2基本概念

    一、Struts2体系结构 :
    1、Web浏览器请求一个资源。
    2、过滤器Dispatcher查找方法,确定适当的Action。
    3、拦截器自动对请求应用通用功能,如验证和文件上传操作。
    4、Action的execute方法通常用来存储和重新获得信息。
    5、结果被返回到浏览器。 

    二、Struts2的具体工作流程
    1、基本流程图


    2、详细解释
    (1)  客户端(Client)向Action发用一个请求(Request)
    (2)  容器(Container)通过web.xml映射请求,并获得控制器(Controller)的名字
    (3)  容器(Container)调用控制器(StrutsPrepareAndExecuteFilter或FilterDispatcher)。在Struts2.1以前调用FilterDispatcher,Struts2.1以后调用StrutsPrepareAndExecuteFilter
    (4)  控制器(Controller)通过ActionMapper获得Action的信息
    (5)  控制器(Controller)调用ActionProxy
    (6)  ActionProxy读取struts.xml文件获取action和interceptor stack的信息。
    (7)  ActionProxy把request请求传递给ActionInvocation
    (8)  ActionInvocation依次调用action和interceptor
    (9)  根据action的配置信息,产生result
    (10) Result信息返回给ActionInvocation
    (11) 产生一个HttpServletResponse响应
    (12) 产生的响应行为发送给客服端。

     

    三、搭建Struts2开发环境

    1、找到开发Struts 2的应用需要用到的jar包。
    2、编写Struts 2的相应Action类并在struts.xml中作相应的配置。
    3、在web.xml中加入Struts 2 MVC启动框架配置。
    开发Struts 2 最少用到的jar文件:
    Struts-core-2.x.x.jar : Struts 2 框架的核心类库
    xwork-2.x.x.jar : XWork类库,Struts 2 在其上构建
    ognl-2.6.x.jar : Object Graph Navigation Language , Struts 2 框架通过其读写对象的属性。
    freemarker-2.3.x.jar : Struts 2 的UI标签的模版使用 Freemarker编写。
    commons-logging-1.1.x.jar : ASF出品的日志包。
    commons-fileupload-1.2.1.jar : 文件上传组件。

    四、配置文件详解
    1、struts.xml
    默认情况下,会从“WEB-INFclasses”下加载struts.xml文件,通过Eclipse开发是在src目录下建立struts.xml文件,发布后会自动拷贝到“WEB-INFclasses”目录下。struts.xml是Struts 2 的核心配置文件,主要用于配置开发人员编写的action。

    (1)基本格式如下:
    <?xml version="1.0" encoding="UTF-8" ?>
    <!DOCTYPE struts PUBLIC
    "-//Apache Software Foundation//DTD Struts Configuration 2.3//EN"
    "http://struts.apache.org/dtds/struts-2.3.dtd">
    <struts>
       <package name="test" extends="struts-default"/>
       <action name="Login1" class="com.chen.LoginAction1" >
       <result>/loginResult.jsp</result>
       <result name="input">/login1.jsp</result>
       </action>
       </package>
    </struts>
    ①通过反射机制将请求参数注入到"com.chen.LoginAction1"类中
    ②调用"com.chen.LoginAction1"类的execute方法,该方法的原型为:public String execute() throws Exception;
    ③ 根据execute方法返回的String类型的字符串(如"input"),在配置文件中查找该字符串对应的页面,并转到该页面。

    (2)标签详解
    <package>标签
    如果要配置<Action>的标签,那么必须要先配置<package>标签,代表的包的概念。包含的属性:
    name         包的名称,要求是唯一的,管理action配置。
    extends      继承,可以继承其他的包,只要继承了,那么该包就包含了其他包的功能,一般都是继承struts-default
    namespace    名称空间,一般与<action>标签中的name属性共同决定访问路径,常见的配置如下:
    namespace=""     -- 默认的名称空间(访问的方式和namespace="/"是一样的)
    namespace="/"    -- 根名称空间
    namespace="/aaa" -- 带有名称的名称空间,这样请求action时,URL是/namespace/name的形式
    abstract         -- 抽象的。这个属性基本很少使用,值如果是true,那么编写的包是被继承的。     

    <action>标签
    代表配置action类,包含的属性:
    name              和<package>标签的namespace属性一起来决定访问路径的。
    class             配置Action类的全类名(默认值是ActionSupport类)
    method            Action类中执行的方法,如果不指定,默认值是execute方法

    <result>标签
    action类中方法执行,返回的结果跳转的页面
    name      结果页面逻辑视图名称
    type        结果类型(默认值是转发,也可以设置其他的值)
    注:
    设置Struts2默认的Action:
    在地址栏上输入一个不存在的action请求,程序会报404的异常。但是在<package>标签中通过<default-action-ref name="指定action标签name属性"></default-action-ref>来设置默认的Action。当在配置文件中找不到相应的action时,就由默认的action进行处理。
    设置Action默认处理类:
    在地址栏上输入一个正确的action请求,但是<action>标签中的class属性没有写具体的Action类也会报异常。在<package>标签中通过<default-class-ref class="指定action类的全路径"></default-class-ref>来设定action的默认处理类。

    2、多个struts的配置文件的合并
    为了避免struts.xml文件过于庞大、臃肿,提高struts.xml文件的可读性,我们可以将一个struts.xml配置文件分解成多个配置文件,然后在struts.xml文件中包含其他配置文件。可以在使用<include>标签来引入其他的struts_xx.xml的配置文件。例如:
    <struts>
    <include file="conf/struts_user.xml"></include>
    <include file="conf/struts_editer.xml"></include>
    </struts>
    这样可以把struts_user.xml和struts_user.xml各自编写,并放到一个文件目录下,使用时strus.xml直接包含这两个配置文件即可。需要注意的是struts_user.xml和struts_user.xml也必须按照strus的配置文件格式来写。

    3、web.xml的配置

    要使用strus2框架,必须在web.xml中配置相应的过滤器。通常情况下web.xml的核心配置如下:

    **********省略了web.xml的一般配置信息**********

        <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>
    ************省略了后续代码**********
    通过<url-pattern>/*</url-pattern>使得struts拦截所有URL请求。而StrutsPrepareAndExecuteFilter中的init()方法中将会读取类路径下默认的配置文件struts.xml完成初始化操作。struts2读取到struts.xml的内容后,以javabean形式存放在内存中,以后Struts2对用户的每一次请求处理将使用内存中的数据。Filter 过滤器是用户请求和处理程序之间的一层处理程序。它可以对用户请求和处理程序响应的类容进行处理,通常用于权限、编码转换等场合。

    五、实现Action
    1、把Action看作是POJO类
    POJO(Plain Ordinary Java Object)简单的Java对象。简单来说,没有继承某个类,没有实现接口,就是POJO的类。我们直接写一个POJO类,把它当作struts2对应的一个Action类。这个类必须包含处理逻辑所需要的属性及相应的get、set方法,并且提供Struts2调用的execute方法。但通常不推荐这样做,这样不利于统一接口。


    2、实现Action接口

    Action接口中定义了5个常量,5个常量的值对应的是5个逻辑视图跳转页面(跳转的页面还是需要自己来配置),还定义了一个方法,execute方法,我们可以自己来实现。
    常量值如下所示:
    SUCCESS       -- 成功.
    INPUT         -- 用于数据表单校验.如果校验失败,跳转INPUT视图.
    LOGIN         -- 登录.
    ERROR         -- 错误.
    NONE          -- 页面不转向.

    3、继承ActionSupport类,而该类实现了Action 、Validateable 、 ValidationAware 、TextProvider、LocaleProvider,Serializable接口。我们只需要根据实际情况重写一些其中的方法就可以满足需求。


    六、实例演示

    利用struts2的框架来实现一个用户登录校验的例子。

    1、在eclipse中创建一个web工程,并导入struts2的关键jar包到WEB-INF的lib目录下。并在WebContext根目录下创建web.xml,在源文件目录src下创建struts.xml。再创建login.jsp和loginResult.jsp两个jsp文件,用于显示登录界面和登录成功界面。最后创建一个Action类,放在自定义的包下。目录和文件创建完毕,总体目录文件结构如下:






    2、配置web.xml和struts.xml两个文件

    web.xml的配置如下:

    <?xml version="1.0" encoding="UTF-8"?>
    <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://xmlns.jcp.org/xml/ns/javaee" xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd" version="3.1">
        <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.3//EN"
    	"http://struts.apache.org/dtds/struts-2.3.dtd">
    
    <struts>
       <package name="LoginTest" extends="struts-default">
       <action name="Login" class="com.chen.LoginAction" >
       <result>/loginResult.jsp</result>
       <result name="input">/login.jsp</result>
       </action>
       </package>
    </struts>
    

    3、编写jsp文件

    login.jsp源码如下:

    <%@ page contentType="text/html;charset=utf-8" %>
    <%@ taglib prefix="s" uri="/struts-tags"%>
    <html> 
    <head><title>登录系统</title></head>
    <body><br><br><br>
    <div align="center">
    <s:text name="welcome message:"/>
    ${requestScope.message}
    <s:form action="Login" method="POST" theme="xhtml">
    	<s:textfield name="adminUserName" label="用户名"/>
    	<s:password name="adminUserPassword" size="21" label="密码"/>
    	<s:submit value="提  交"/>
    </s:form>
    </div>
    </body>
    </html>

    注意到login.jsp中使用了struts2的标签,所以需要有

    <%@ taglib prefix="s" uri="/struts-tags"%>

    ${requestScope.message}显示出登录信息,message的设置在Action类中。

    form中设置action="Login",这与struts.xml中的 

    <action name="Login" class="com.chen.LoginAction" >保持一致。也就是说,这个表单的数据会提交给com.chen.LoginAction来进行处理。


    loginResult.jsp源码如下:

    <%@ page contentType="text/html;charset=utf-8" %>
    <html>
    <head>
    <title>验证通过</title>
    </head>
    <body>
     ${message}
    </body>
    </html>


    4、编写Action类

    我们采用继承ActionSupport类的方法来编写自定义的Action类LoginAction。源码如下:

    注:这里为了便于测试,直接把用户名和密码都设为admin。实际应用中一般要连接数据库。

    package com.chen;
    import com.opensymphony.xwork2.ActionContext;
    import com.opensymphony.xwork2.ActionSupport;
    
    public class LoginAction extends ActionSupport {
    	/**
    	 * 
    	 */
    	private static final long serialVersionUID = 1L;
    	/**
    	 * 执行用户验证的方法
    	 */
    	public String execute() throws Exception {
    		if("admin".equals(adminUserName)&&"admin".equals(adminUserPassword))
    			message=adminUserName+"登录成功!";
    		else{
    			message=adminUserName+"登录失败!";
    			return INPUT;//转到输入界面
    		}
    		return SUCCESS;//转到登录成功界面
    	}
    	public String adminUserName;//用户名
    	public String adminUserPassword;//密码
    	public String message;//execute()执行完后返回的消息
    	public String getAdminUserName() {
    		return adminUserName;
    	}
    	public void setAdminUserName(String adminUserName) {
    		this.adminUserName = adminUserName;
    	}
    	public String getAdminUserPassword() {
    		return adminUserPassword;
    	}
    	public void setAdminUserPassword(String adminUserPassword) {
    		this.adminUserPassword = adminUserPassword;
    	}
    	public String getMessage() {
    		return message;
    	}
    	public void setMessage(String message) {
    		this.message = message;
    	}
    	
    }
    

    5、编写完毕,将项目运行在Tomcat上,测试即可。

    原始界面:


    登录失败:

    登录成功:






  • 相关阅读:
    linux下的crontab定时执行任务命令详解
    494. Target Sum
    347. Top K Frequent Elements
    5. Longest Palindromic Substring
    时间复杂度计算方法
    62. Unique Paths
    54. Spiral Matrix && 59. Spiral Matrix II
    57. Insert Interval
    53. Maximum Subarray
    42.Trapping rain water
  • 原文地址:https://www.cnblogs.com/kangsir/p/6653270.html
Copyright © 2011-2022 走看看