当前位置:文档之家› 关于struts2中prepare接口实现数据准备

关于struts2中prepare接口实现数据准备

关于struts2中prepare接口实现数据准备
关于struts2中prepare接口实现数据准备

关于struts2中prepare接口实现数据准备

之前做过不少的项目,所有的action只实现了一个execute()方法,也用到过Preparable接口,并没注意到它的具体用法。随着项目的需求的增加,按照以前的方法,每一个功能都需要一个action,这样势必会造成action类的大规模膨胀。所以决定采取action!method的形式,这样在一个action中可以包含很多方法,减少了action类的数量,也便于维护。

把crud方法放在一个action类中,就必定会涉及到一些数据准备的事情,所以用Preparable接口就再合适不过了,实现这个接口的prepare()方法,这个方法会在action类的所有方法执行前执行,另外我们也可以按照它的规则来写一些其它形式的prepare方法,例如aciton中有一个方法叫input(),那么我们可以实现一个prepareInput方法,这样在input()执行前,会执行prepareInput()方法。

好了,言归正传,我们有这样的一个action:

Java代码

1.package ht.gisoa.action;

2.

3.import ht.gisoa.model.Sysconfig;

4.import ht.gisoa.service.SysconfigManager;

5.

6.import java.util.List;

7.import java.util.Map;

8.

9.import javax.servlet.http.HttpServletRequest;

10.

11.import

https://www.doczj.com/doc/5615056639.html,dParameterJdbcTemp

late;

12.

13.import com.opensymphony.webwork.ServletActionContext;

14.import

com.opensymphony.webwork.interceptor.ServletRequestAware;

15.import com.opensymphony.webwork.interceptor.SessionAware;

16.import com.opensymphony.xwork.ActionSupport;

17.import com.opensymphony.xwork.ModelDriven;

18.import com.opensymphony.xwork.Preparable;

19.import com.thoughtworks.xstream.XStream;

20.

21.public class SystemConfigAction extends ActionSupport implements

Preparable,SessionAware,ServletRequestAware,ModelDriven{

22./**

23.*

24.*/

25.

26.private Map session ;

27.private HttpServletRequest request;

28.

29.private NamedParameterJdbcTemplatenamedParameterJdbcTemplate =

null;

30.

31.private Double hignSpeed = 0.0;

32.private Double midSpeed = 0.0;

33.private Double lowSpeed = 0.0;

34.

35.private static final long serialVersionUID = 1L;

36.private SysconfigManagersysconfigManager = null;

37.

38.

39.private Long id ;

40.private Sysconfig entity;

41.

42.public void setId(Long id) {

43.this.id = id;

44.}

45.

46.public String editSpeed() throws Exception{

47.Mapconfigs =

sysconfigManager.getSpeedConfig() ;

48.ServletActionContext.getRequest().setAttribute("configs",

configs);

49.return this.SUCCESS;

50.}

51.

52.public String input() throws Exception{

53.return "input";

54.}

55.

56.public String list(){

57.ListspeedCollection =

sysconfigManager.getSpeedList();

58.ServletActionContext.getRequest().setAttribute("speedCollection

", speedCollection);

59.return "list";

60.}

61.

62.public String save() throws Exception{

63.sysconfigManager.mergy(entity);

64.return "reload";

65.}

66.

67.public String delete() throws Exception{

68.sysconfigManager.delete(id);

69.return "reload";

70.}

71.

72.public SysconfigManagergetSysconfigManager() {

73.return sysconfigManager;

74.}

75.public void setSysconfigManager(SysconfigManagersysconfigManager)

{

76.this.sysconfigManager = sysconfigManager;

77.}

78.

79.public Double getHignSpeed() {

80.return hignSpeed;

81.}

82.

83.public void setHignSpeed(Double hignSpeed) {

84.this.hignSpeed = hignSpeed;

85.}

86.

87.public Double getMidSpeed() {

88.return midSpeed;

89.}

90.

91.public void setMidSpeed(Double midSpeed) {

92.this.midSpeed = midSpeed;

93.}

94.

95.public Double getLowSpeed() {

96.return lowSpeed;

97.}

98.

99.public void setLowSpeed(Double lowSpeed) {

100.this.lowSpeed = lowSpeed;

101.}

102.

103.public void setSession(Map session) {

104.this.session = session;

105.}

106.

107.public void setServletRequest(HttpServletRequest request) { 108.this.request = request;

109.}

110.

111.public void prepare() throws Exception {

112.

113.}

114.

115.public void prepareModel() throws Exception {

116.if (id==null){

117.System.out.println("id=null");

118.entity = new Sysconfig();

119.entity.setKeyType(1L);

120.}else{

121.System.out.println("id=="+id);

122.entity = sysconfigManager.get(id);

123.}

124.}

125.

126.public void prepareInput() throws Exception{

127.prepareModel();

128.}

129.public void prepareSave() throws Exception {

130.prepareModel();

131.}

132.

133.public Object getModel() {

134.return entity;

135.}

136.}

这里要注意,要在spring中配置该action的作用域为prototype,否则,不同

的方法之间会出现数据混乱的情况:

Xml代码

1.

2.class="ht.gisoa.action.SystemConfigAction" scope="prototype">

3.

4.

5.

6.

sysconfig_input.jsp代码如下:

Jsp代码

1.<%@ page language="java" pageEncoding="UTF-8"

isELIgnored="false"%>

2.<%@ tagliburi="https://www.doczj.com/doc/5615056639.html,/jstl/core_rt" prefix="c"%>

3.

4.01 Transitional//EN"

"https://www.doczj.com/doc/5615056639.html,/TR/html4/loose.dtd">

4.

5.

6.

7.

8.

9.

10.

11.${msg}

12.

13.创建

修改设置

14.

15.

16.

value="${model.keyName}"/>

17.

value="${model.keyValue}"/>

18.

19.

20.

21.

22.

23.

24.

25.

我们编辑完信息,提交后,会执行action中的save方法,按道理,表单提交后,会将action中的model填充好数据,但是save方法之前又会执行prepareSave 方法,从数据库里获取一次数据,这样不就把之前填充好的数据冲掉了吗?仔细想想也确实是这样的.

那么该如何解决这种矛盾呢,立即使出google大法,查了一下关于interceptor 的资料,有这样的一个interceptor:paramsPrepareParamsStack,paramsPrepareParamsStack主要解决了ModelDriven和Preparable的配合问题,从字面上理解来说,这个stack的拦截器调用的顺序为:首先params,然后

prepare,接下来modelDriven,最后再params。Struts 2.0的设计上要求modelDriven在params之前调用,而业务中prepare要负责准备model,准备model又需要参数,这就需要在prepare之前运行params拦截器设置相关参数,这个也就是创建paramsPrepareParamsStack的原因。流程如下:

1. params拦截器首先给action中的相关参数赋值,如id

2. prepare拦截器执行prepare方法,prepare方法中会根据参数,如id,去调用业务逻辑,设置model对象

3. modelDriven拦截器将model对象压入value stack,这里的model对象就是在prepare中创建的

4. params拦截器再将参数赋值给model对象

5. action的业务逻辑执行

我的xwork.xml中相关配置如下:

Xml代码

1.

2.

3.syscfg_speed_list.jsp

4.

5.

6.systemconfig!list.action

7.

8.

9.syscfg_speed_input.jsp

10.

11.

12.

13.

通过paramsPrepareParamsStack可以让流程更明确,代码更简洁,也更利于大家的交流。

SCME_STRUTS2试卷

--------------------------------------装--------------------------------------订------------------------------线---------------------------------------- **学院课程考试试卷 课程名称:《使用Struts2开发基于MVC设计模式的企业级应用》(A)卷 年级:班级: 姓名:_______________ 学号:_________________ 考试(考查) 闭卷 选择题(每题2分,共计100分) 1.在控制器类中一般需要添加相应属性的( A )和(C )。(选两项) A.setter方法 B.as方法 C.getter方法 D.is方法 2.业务控制器需要在( B )配置文件中进行配置 A.web.xml B.struts.xml C.struts2.xml D.webwork.xml 3.不属于Struts 2表单标签库的是( D )。 A. B. C. D. 9. 在JSP页面中可以通过Struts2提供的()标签来输出国际化信息 a) b) c) d) 10. 资源文件的后缀名为() a) txt b) doc c) property d) properties 11. struts2自定义类型转换器必须实现的接口是() a) Convert b) TypeConverter c) StrutsTypeConverter d)StrutsConvert 12. struts2关于注册全局类型转换器的说法正确的是()【选择二项】 a) 必须提供xwork-conversion.properties文件 b) 注册文件的格式为:复合类型=对应类型转换器 c) 注册文件的格式为:对应类型转换器=复合类型 d) 以上说法都不正确 13. struts2自定义拦截器中的“return invocation.invoke”代码表示() 【选择二项】 a) 不执行目标Action的方法,直接返回 b) 执行目标Action的方法,直接返回逻辑视图名称 c) 在自定义拦截器中,该代码是必需的 d) 在自定义拦截器中,该代码是可选的 14. struts2中,以下配置文件上传拦截器只允许上传bmp图片文件的代码, 正确的是() a) image/bmp b) *.bmp c) bmp d) image/*.bmp 15. 以下关于OGNL的说法正确的是()【选择二项】 a) ActionContext是OGNL的上下文环境 b) StackContext是OGNL的上下文环境

struts2标签使用实例

Struts2中数据标签使用示例 S truts2提供了大量丰富的标签供使用,它不再像S truts1中一样,将种类标签进行分门列别,但可以根据其使用的用途用以区别。本文通过对S truts2中数据标签的学习,来对S truts2中标签的学习起到一个抛砖引玉的作用。 文中将介绍Action标签、Bean标签、Data标签、Include标签、P aram标签、Set标签、T ext标签、P roperty 标签等标签。 代码下载:https://www.doczj.com/doc/5615056639.html,/y1ps2Mjpc3NiLKuetMOpCsZOOypD6KSdo8-46Zy2wpoMcABeo4vOC NJXtWDEO93-TXgZogwAF YxSOni5BEG2EoN65OFwHdG71v-/St ruts2DataTags.rar?download 一、标签 Action标签,顾名思义,是用来调用Action的标签,在JSP中页面中,可以指向具体指定某一命名空间中的某一Action。而标签的主体用于显示及渲染Actionr的处理结果。 1.WebRoot\pages\dataTagssuccess.jsp处理页面 <%@ page contentType="text/htm l; charset=GBK" %> <%@ taglib prefix="s" uri="/struts-tags" %> Action Tag 示例

Action Tag 示例

s:action标签用于在页面显示结果.
这里使用标签进行页面跳转,并用于显示处理的结果。 2.先来看st ruts.xml中的配置: /pages/dataTags/success.jsp

2.3 基本数据类型的转换

2.3基本数据类型的转换 本章目标 掌握基本数据类型间的自动转换 掌握任何基本数据类型的数据都会自动向String转换 掌握基本数据类型间的强制转换 Java的数据类型在定义时就已经确定了,因此不能随意转换成其他的数据类型,但Java允许用户有限度地做类型转换处理。数据类型的转换方式可分为“自动类型转换”及“强制类型转换”两种。 1 数据类型的自动转换 在计算机中完成一个计算时,要求参与计算的两个数值必须类型一致,如果不一致,计算机会自动将其中一个数值类型转换成另外一个数值的类型,然后完成计算。自动转换的原则如下: (1)转换前的数据类型与转换后的类型兼容。 (2)转换后的数据类型的表示范围比转换前的类型大。 例如,将short类型的变量a转换为int类型,由于short与int皆为整数类型,符合上述条件(1);而int的表示范围比short大,符合条件(2)。因此Java 会自动将原为short类型的变量a转换为int类型。 要注意的是,类型的转换只限该行语句,并不会影响原先所定义的变量的类型,而且通过自动类型的转换可以保证数据的精确度,它不会因为转换而损失数据内容。这种类型的转换方式也称为扩大转换。 范例:数据类型的转换 程序运行结果: x / y = 1.3519603 10 / 3.5 = 2.857142857142857 10 / 3 = 3 从程序的输出结果可以发现,int类型与float类型进行计算之后,输出的结

果会变成float类型,一个整型常量和一个浮点型常量进行计算之后,结果也会变为一个浮点数据,而如果两个int类型的常量进行计算,最终结果还是int类型,而其小数部分将会被忽略。 也就是说,假设有一个整数和双精度浮点数据做运算时,Java会所整数转换成双精度浮点数后再做运算,运算结果也会变成双精度浮点数。 提示:任何类型的数据都向String转型。 有一种表示字符串的数据类型String,从其定义上可以发现单词首字母大写了,所以此为一个类,属于引用数据类型,但是此类属于系统类,而且使用上有些注意事项,对于此种类型后面会有介绍,在此处所需要知道的只有以下两点: (1)String可以像普通变量那样直接通过赋值的方式进行声明。字符串是使用“””括起来的。两个字符串之间可以使用“+”进行连接。 (2)任何数据类型碰到String类型的变量或常量之后都向String类型转换。 范例:定义字符串变量 程序运行结果: str = lixinghua30 从运行结果来看,可以发现整型数据30自动转换成了字符的“30”,与字符串“lixinghua”进行了连接操作,变成了一个新的字符串“lixinghua30”。 范例:字符串常量操作的问题

Struts2的工作机制原理分析及实例

Struts2的工作机制分析及实例 一、概述 本章讲述Struts2的工作原理。 读者如果曾经学习过Struts1.x或者有过Struts1.x的开发经验,那么千万不要想当然地以为这一章可以跳过。实际上Struts1.x 与Struts2并无我们想象的血缘关系。虽然Struts2的开发小组极力保留Struts1.x的习惯,但因为Struts2的核心设计完全改变,从思想到设计到工作流程,都有了很大的不同。 Struts2是Struts社区和WebWork社区的共同成果,我们甚至可以说,Struts2是WebWork的升级版,他采用的正是WebWork 的核心,所以,Struts2并不是一个不成熟的产品,相反,构建在WebWork基础之上的Struts2是一个运行稳定、性能优异、设计成熟的WEB框架。 本章主要对Struts的源代码进行分析,因为Struts2与WebWork的关系如此密不可分,因此,读者需要下载xwork的源代码,访问https://www.doczj.com/doc/5615056639.html,/xwork/download.action即可自行下载。 下载的Struts2源代码文件是一个名叫struts-2.1.0-src.zip的压缩包,里面的目录和文件非常多,读者可以定位到 struts-2.1.0-src\struts-2.0.10\src\core\src\main\java目录下查看Struts2的源文件,如图14所示。 (图14) 二、主要的包和类 Struts2框架的正常运行,除了占核心地位的xwork的支持以外,Struts2本身也提供了许多类,这些类被分门别类组织到不同的包中。从源代码中发现,基本上每一个Struts2类都访问了WebWork提供的功能,从而也可以看出Struts2与WebWork千丝万缕的联系。但无论如何,Struts2的核心功能比如将请求委托给哪个Action处理都是由xwork完成的,Struts2只是在WebWork 的基础上做了适当的简化、加强和封装,并少量保留Struts1.x中的习惯。

java的基本数据类型有八种

java的基本数据类型有八种 各位读友大家好!你有你的木棉,我有我的文章,为了你的木棉,应读我的文章!若为比翼双飞鸟,定是人间有情人!若读此篇优秀文,必成天上比翼鸟! java的基本数据类型有八种四类八种基本数据类型1. 整型byte(1字节)short (2个字节)int(4个字节)long (8个字节)2.浮点型float(4个字节)double(8个字节)3.逻辑性boolean(八分之一个字节)4.字符型char(2个字节,一个字符能存储下一个中文汉字)基本数据类型与包装类对应关系和默认值short Short (short)0int Integer 0long Long 0Lchar Char '\u0000'(什么都没有)float Floa t0.0fdouble Double 0.0dboolean Boolean false 若某个类的某个成员是基本数据类型,即使没有初始化,java也会确保它获得一个默认值,如上所示。(这种初始化方法只是用于成员变量,不适用于局部变量)。jdk1.5支持自动拆装箱。可以将基本数据类型转换成它的包装类装箱Integer a = new Integer ();a = 100;拆箱int b = new Intger(100);一个字节等于8位,一个字节等于256个数,-128到127一个英文字母或一个阿拉伯数字就是一个字符,占用一个字节一个汉字两个字符,占用两个字节基本数据类型自动转换byte->short , char->int->longfloat->doubleint ->floatlong->double小可转大,大转小会失去精度。字符串与基本类型或其他类型间的转换⑴其它

struts2题目

1.下面关于Struts2描述正确的是()。 A. Struts2是线程安全的 B. Strut2为每个请求都只生成一个Action实例 C .Strut2是在Struts1基础上发展起来的 D. Struts2只支持jsp视图组件 2.Struts2配置包时,必须继承struts-default包,在下 面的哪个文件中可以找到struts-default包的配置()。 A.default.properties B. struts-message.properties C. struts.dtd D.struts-default.xml 3.Struts2默认的处理结果类型是()。 A. dispatcher B. redirect C. chain D. 以上说法都不正确 4.在Struts2框架中,实现Action接口的作用是()。 A.实现其中的execute()方法 B.实现数据校验 C.实现国际化 D.规范Action类 5.在Struts2中动态方法调用的格式为()。 A. ActionName_methodName.do B. ActionName!methodName.do C. ActionName_methodName.action D. ActionName!methodName.action 6.在Struts2中自定义的类型转换器必须实现的接口是 ()。 A.Convert B.TypeConverter C. StrutsTypeConverter D. StrutsConvert 7.在Struts2中,Action类中的属性从表单获取用户输入 的值,以下哪个组件将表单的值解析出来赋给Action ()。 A. ActionServlet B. Action C. 拦截器栈 D. HttpServletRequest 8.在Struts2中,关于

Liferay Struts2 完整实例 修正

目录 一.Liferay,ext开发环境的搭建 (1) 二.集成struts2 (3) 1.依赖包: (3) 2.使用Struts2 (3) 三.使用Hibernate. Spring (4) 1.建立bean (4) 2.建立事务层: (5) 3 .建立持久层 (8) 4. Action 中调用事务层 (10) 三.将portlet注册到portal (11) 四.加入国际化 (13) 五.加入处理页面 (13) 2010年12月20日,修改在页面上的标签找不到国际化信息。 一.Liferay,ext开发环境的搭建 1.进入myeclipse,修改liferay-portal-src-5. 2.3文件名为portal。导入portal到eclipse. 2.展开portal工程目录,我们可看到一个release.properties文件, 新建一个它的扩展配置文件, 文件名为release.${username}.properties。 ${username}是计算机当前用户名 我文件名是release.Administrator.properties,文件内容只一行:lp.ext.dir=D:\myspace\ext 即扩展工程放置路径。 3.打开myeclipse里面ant视图(window--> show view --> ant) , 在ant视图中,点击添加, 选择:\portalspace\portal\目录下build.xml 顺序执行clean ,start ,build-ext

4.将liferay-portal-tomcat-6.0- 5.2.3.zip解压到D:\portalspace\目录下,并更名为servers。 在D:\portalspace\ext目录下我们可以看到app.server.properties文件, 同样我们也要建立一个扩展配置文件app.server.${username}.properties,文件内容两行:lp.ext.dir=D:/myspace/ext app.server.type=tomcat app.server.tomcat.dir=D:/ myspace /servers/tomcat-6.0.18 5.将myspace/ext 工程导入到eclipse中。 6.打开window --> preference --> myeclipse --> application servers 将其他应用服务器 disabble掉, 找到tomcat6,将tomcat home diretory 指向D:\myspace\servers\tomcat-6.0.18, 展开tomcat6,JDK选择我们配置好的JDK1.5+, JDK选项下面optional java vm argument输入如下内容: -Xms128m -Xmx256m -XX:MaxPermSize=128m 7.建立数据库lportal 。在D:\myspace\ext\ext-impl\src\portal-ext.properties文件中添加数据 库连接信息 # MySQL jdbc.default.driverClassName=com.mysql.jdbc.Driver jdbc.default.url=jdbc:mysql://localhost:3306/lportal https://www.doczj.com/doc/5615056639.html,ername=root jdbc.default.password=root hibernate.dialect=org.hibernate.dialect.MySQLDialect 若不添加以上内容liferay就会使用自带默认数据库. 8.选择 :\myspace\ext\目录下build.xml 顺序执行clean,deploy 将ext项目部署到 tomcat-6.0.18. 然后选择eclipse中的tomcat6.0启动即可 9.在浏览器里输入http://localhost:8080/可以看到portal系统了。输入emal: test@https://www.doczj.com/doc/5615056639.html, password: test登录

数据类型转换

数据类型转换 一、隐式类型转换 1)简单数据类型 (1)算术运算 转换为最宽的数据类型 eg: [cpp] view plain copy #include using std::cout; using std::endl; int main(int argc, char* argv[]) { int ival = 3; double dval = 3.14159; cout << ival + dval << endl;//ival被提升为double类型 return 0; } 其运行结果: 6.14159 int main(int argc, char* argv[]) { 010D17D0 push ebp 010D17D1 mov ebp,esp 010D17D3 sub esp,0DCh 010D17D9 push ebx 010D17DA push esi 010D17DB push edi 010D17DC lea edi,[ebp-0DCh] 010D17E2 mov ecx,37h 010D17E7 mov eax,0CCCCCCCCh 010D17EC rep stos dword ptr es:[edi] int ival = 3; 010D17EE mov dword ptr [ival],3 double dval = 3.14159; 010D17F5 movsd xmm0,mmword ptr [__real@400921f9f01b866e (010D6B30h)]

010D17FD movsd mmword ptr [dval],xmm0 cout << ival + dval << endl;//ival被提升为double类型 010D1802 mov esi,esp 010D1804 push offset std::endl > (010D1064h) 010D1809 cvtsi2sd xmm0,dword ptr [ival] 010D180E addsd xmm0,mmword ptr [dval] 010D1813 mov edi,esp 010D1815 sub esp,8 010D1818 movsd mmword ptr [esp],xmm0 010D181D mov ecx,dword ptr [_imp_?cout@std@@3V?$basic_ostream@DU?$char_traits@D@std@@@1@A (010D90A8h)] 010D1823 call dword ptr [__imp_std::basic_ostream >::operator<< (010D90A0h)] 010D1829 cmp edi,esp 010D182B call __RTC_CheckEsp (010D111Dh) 010D1830 mov ecx,eax 010D1832 call dword ptr [__imp_std::basic_ostream >::operator<< (010D90A4h)] 010D1838 cmp esi,esp 010D183A call __RTC_CheckEsp (010D111Dh) return 0; 010D183F xor eax,eax } 010D1841 pop edi } 010D1842 pop esi 010D1843 pop ebx 010D1844 add esp,0DCh 010D184A cmp ebp,esp 010D184C call __RTC_CheckEsp (010D111Dh) 010D1851 mov esp,ebp 010D1853 pop ebp 010D1854 ret (2)赋值 转换为被赋值对象的类型,但不会改变赋值对象的数据类型。 eg: [cpp] view plain copy #include

相关主题
文本预览
相关文档 最新文档