浅谈Struts2(三)
一、Struts2收集client的参数
核心思路:
<form method="post" action="XXXX">
<input type="text" name="username"/>
<input type="text" name="password"/> <input type="text" name="user.age"/> <input type="checkbox" name="hobby"/>
<input type="submit" value="ok"/>
</form>
html/jsp通过form表单提交数据。
//代码仅为示例
public class FirstServlet implements Action{
private User user;
private String username;
private String password; private String[] hobby;
public void setUsername(String username){
this.username = username;
}
public String getUsername(){
return this.username;
}
...
}
在Action中声明成员变量同时声明get、set方法,成员变量的名字跟html/jsp要传递的数据名保持一致。
在这种情况下,struts2会自动将client传递的数据写入到所跳转Action中对应的成员变量中,既可以自动写简单数据,也可以写入复杂数据(对象、数组、集合)。
好处:
a、简单,方便。
b、自动把提交的数据进行类型转换。
c、自动对post中提交的中文进行转码处理(只针对UTF-8格式)。
二、Struts2的动态方法调用
1、Action的第二种开发形式
之前是通过implements Action接口来开发我们自己的Action的,其实更好的方法是extends ActionSupport类来开发我们的Action。
ActionSupport类实现了Action接口,并且提供了execute()方法的空实现,并返回了"success"。
用这种方法的好处是为了动态方法的调用。
2、DMI(Dynamic Method Invoke)动态方法调用
作用:可以在一个Action中提供多个方法,减少系统中Action的数量,便于管理与维护。
java代码:
public class UserAction extends ActionSupport{
public String addUser(){
System.out.println("----this is addUser method----");
return "addUser";
}
public String delUser(){
System.out.println("----this is delUser method----");
return "delUser";
}
public String modifyUser(){
System.out.println("----this is modifyUser method----");
return "modifyUser";
}
}
struts.xml配置:
<action name="user_*" class="com.liquidxu.struts2.UserAction" method="{1}">
<result name="addUser">/result.jsp</result>
<result name="delUser">/result.jsp</result>
<result name="modifyUser">/result.jsp</result>
</action>
访问http://localhost:8080/struts_app/user_addUser,其中的addUser为所访问的Action中的方法名(必须保持一致),并且填充了配置文件中的{1}和*。
二、Struts2的数据处理机制
1、OGNL表达式
OGNL表达式是一种获取数据的技术。是一个独立的技术组件,不属于struts2框架,只是被struts2借用。
2、ValueStack(值栈)
作用:管理(储存)一次请求中,所涉及的数据(client提交的数据+作用域中的数据request、session、application)。
好处:与视图层解耦和。
a、ValueStack的获取方式
ActionContext ctx = ActionContext.getContext();
ps、ValueStack的生命周期为一个请求有效(等同于request作用域),换请求,值栈也会随之改变。
b、ValueStack的内存结构

ValueStack分为两个区域,root区和contextMap区。root区主要存当前访问的Action和标签处理的临时结果,contextMap区默认存有四部分内容,分别存有request、session、application作用域和parameters(client请求数据)。可以通过上图右侧的代码示例来从contextMap区中取值。
3、值栈的灵活应用
a、使用Action的成员变量替换request作用域(间接用值栈的root区)。
因为值栈root区储存有当前访问的Action,所以如果需要用request作用域储存的数据,直接储存在当前Action的成员变量,然后在view层利用OGNL表达式从root区取出即可。
b、值栈操作的封装
值栈的操作时颇为麻烦的,每次都需要做许多重复的操作,所以应该做如下封装:
public class BaseAction extends ActionSupport{
private ValueStack vs;
public BaseAction(){
ActionContext ctx = ActionContext.getContext();
vs = ctx.getValueStack();
}
public void setSessionAttribute(String name,Object value){
vs.setValue("#session."+name,value);
}
public Object getSessionAttribute(String name){
return vs.findValue("#session."+name);
}
public void setApplicationAttribute(Stirng name,Object value){
vs.setValue("#application."+name,value);
}
public Object getApplicationAttribute(String name){
return vs.findValue("#application."+name);
}
}
再编写我们自己的Action的时候,就不再extends ActionSupport了,而是继承我们所封装的BaseAction。这样的话,在Action中进行值栈操作的时候就会方便很多。
4、Struts2的标签
<%@taglib uri="/struts-tags" prefix="s">
作用:在jsp页面中,负责显示数据。使用标签替换java脚本。
a、单个数据显示
<s:property value="OGNL表达式"/>
b、有条件显示数据
<s:if test="OGNL表达式">
XXX
</s:if>
<s:elseif test="OGNL表达式">
XXX
</s:elseif>
c、显示多个数据
(1)遍历集合、数组
<s:iterator value="OGNL表达式">
<s:property />
</s:iterator>
(2)遍历map
<s:iterator value="OGNL表达式">
<s:property value="key"/><s:property value="value">
</s:iterator>
(3)遍历状态
<s:iterator value="OGNL表达式" status="sta">
#sta.count //当前遍历次数
#sta.index //获得当前遍历下标
#sta.even //当前是否为偶次遍历
#sta.odd //当前是否为奇次遍历
</s:iterator>
<s:iterator value="OGNL表达式" begin="起始遍历下标" end="结束遍历下标" step="步长">
<s/iterator>
d、<s:date name="ONGL表达式" format="yyyy-MM-dd"/> 处理日期类型
e、<s:url context="${pageContext.request.request.contextPah}(动态获取项目名称)"/>处理url链接
(1)访问Action的处理
<s:url namespace="" action="" />
(2)访问其他资源(css、jsp)
<s:url value="资源的路径"/>
f、<s:action />把多个Action的处理结果,进行汇总。
浅谈Struts2(三)的更多相关文章
- 浅谈struts2之chain
转自:http://blog.csdn.net/randomnet/article/details/8656759 前一段时间,有关chain的机制着实困绕了许久.尽管网上有许多关于chain的解说, ...
- 浅谈C++三种传参方式
浅谈C++三种传参方式 C++给函数传参中,主要有三种方式:分别是值传递.指针传递和引用传递. 下面通过讲解和实例来说明三种方式的区别. 值传递 我们都知道,在函数定义括号中的参数是形参,是给函数内专 ...
- 浅谈 Struts2 面试题收藏
Struts2面试题 一.工作原理 一个请求在Struts2框架中的处理大概分为以下几个步骤 1 客户端初始化一个指向Servlet容器(例如Tomcat)的请求 2 这个请求经过一系列的过滤器(Fi ...
- 浅谈Struts2拦截器的原理与实现
拦截器与过滤器 拦截器是对调用的Action起作用,它提供了一种机制可以使开发者定义在一个action执行的前后执行的代码,也可以在一个action执行前阻止其执行.同时也是提供了 ...
- [SSH 2] 以网站主页面浅谈Struts2配置
导读:前面总体的介绍了一下SSH框架,那么作为Struts这一支,具体是怎么配置的呢?本篇博客则主要是以自己做过的实例中的登录一条线,简单介绍一下struts2的配置,如有不妥之处,还请大家多提点提点 ...
- 浅谈Struts2(一)
一.Struts2引言 1.Struts2框架的概念 解决的MVC开发过程中,控制器(Controller)的通用问题. a.什么是MVC开发 MVC开发是一种编程思想,由设计者人为的把一个项目,划分 ...
- 浅谈struts2的国际化----i18n
可能大家在使用struts框架的时候,偶尔会看到这个词: i18n.也就是 Internationalization i 开头,n 结尾. 总共18个字母,今天的主要内容就是环绕这 四个字母. ...
- 浅谈Struts2
学过SSH框架很长一段时间了,一直没有很系统的总结一下,这里先简单谈谈Struts2. 为什么要用Struts2? 这里列举一些Servlet的缺点: 1.每写一个servlet在web.xml中都要 ...
- 小学生之浅谈Struts2与struts1的运行机制
Struts1工作原理图: 1.初始化:struts框架的总控制器ActionServlet是一个Servlet,它在web.xml中配置成自动启动的Servlet,在启动时总控制器会读取配置文件(s ...
随机推荐
- STL中用erase()方法遍历删除元素
STL中的容器按存储方式分为两类,一类是按以数组形式存储的容器(如:vector .deque):另一类是以不连续的节点形式存储的容器(如:list.set.map).在使用erase方法来删除元素时 ...
- oracle重新启动步骤
1. 停应用层的各种程序. $lsnrctl stop 3. 在独占的系统用户下,备份控制文件: SQL>alter database backup controlfile to trace ...
- FPGA中浮点运算实现方法——定标
有些FPGA中是不能直接对浮点数进行操作的,仅仅能採用定点数进行数值运算.对于FPGA而言,參与数学运算的书就是16位的整型数,但假设数学运算中出现小数怎么办呢?要知道,FPGA对小数是无能为力的,一 ...
- [转]eclipse借助hibernate tool从数据库逆向生成Hibernate实体类
如何从数据库逆向生成Hibernate实体类呢??? 1. 首先,要在eclipse中采用自带的数据库管理器(Data Management),连通你的数据库: 然后选择数据库,这里用的oracle, ...
- Mvc--Html.ActionLink()用法
},new{ target="_blank"})会生成 <a href="Products/Detail/1" target="_blank&q ...
- java 调用jdbc 实现excel和csv的导入和导出
jdbc 的连接 实体类 package com.gpdi.mdata.web.manage.database.data;public class DBQueryData {private Strin ...
- TOJ 1139.Compromise
2015-06-03 问题简述: 大概就是输入两段文本(用小写英文字母表示),分别用#表示一段话的结束输入,输出这两个文本的最长公共子序列. 简单的LCS问题,但是输入的是一段话了,而且公共部分比较是 ...
- Linux学习之输入输出重定向
转自:http://www.cnblogs.com/chengmo/archive/2010/10/20/1855805.html 多谢分享 在了解重定向之前,我们先来看看linux 的文件描述符. ...
- poj 1949 Chores 最长路
题目链接 求出最长路..... #include <iostream> #include <vector> #include <cstdio> #include & ...
- hdu 3529 Bomberman - Just Search! 重复覆盖
题目链接 依然是重复覆盖的模板.... #include<bits/stdc++.h> using namespace std; #define pb(x) push_back(x) #d ...