朋友推荐,说javaeye挺好,今天晚上就申了一个~感觉不错~最近也没写什么,把我以前写过的一个文章贴到这里,算是冲个数吧~嘿嘿~
两个jsp页面通过xwork传数据的几个方式:
这几个方法是在做项目时用到的,记在这里,如果忘记了可以参考一下,大家如果感兴趣,也可以参考一下,我想对初学webwork的应该会有一些帮助,我做东西没太多的经验,可能有很多地方说的不对,写得时候也是按照自己的理解写上去的,例子里的代码,是我做东西时候的真实代码,也是可行的,主要是说明一下怎么做。
起初属于无奈,因为不能经过后台连接数据库得到数据,即使能得到,也是很麻烦,很耗费时间,无奈通过xwork进行传值!现在发现挺好的一件事情,也许有弊端,但我的经验不足,暂时并没有发现,如果有什么不对的地方,希望大家给点意见,批评一下,呵呵,我是大一的学生!
1.如果这个页面的数据要给下一个页面,且不经过java文件处理,可以用这个方法!
那是一个request的周期问题,因为在两个jsp界面通过xwork进行跳转,需要传相同的数据或者下一个界面要用到上一个jsp页面的数据时就可以像下面那样传值,要注意的是,两个jsp页面,在xwork跳转的时候不能经过java文件也就是不能让另一个java文件进行处理,如果在经过一个java文件,那么request存储的数据就会丢失!相反,request存储的数据就会存在。
例如,
jsp:
<c:url var="testContent" value="/admin/addcontent.action">
<c:param name="testId" value="${test.testId}"/>
<c:param name="categoryId" value="${test.categoryId}"/>
</c:url>
<a href="${testContent}">添加</a>
xwork中:
<action name="addcontent">
<result>/dream/admin/addcontent.jsp</result>
</action>
不需要做任何的处理,但要记住,不能经过后台!(也许可以经过后台,只要不进行存储数据就可以,但我没试过,因为那样就没有意义了!)
另一个jsp(addcontent.jsp):
<ww:a href="admin/getTestList.action?model.category_id=${param.categoryId}&id=${param.categoryId}" value="返回">
返回
</ww:a>
<form action="admin/addTestContent.action" method="post" enctype="multipart/form-data">
<input type="hidden" name="categoryId" value="${param.categoryId}">
<input type="hidden" name="content.testId" value="${param.testId}">
<table align="center">
<ww:textfield label="名称" name="content.contentName" value="" required="true"/>
<tr>
<td>上传文件</td>
<td colspan="2">
<input type="file" name="file1"><br/>
<input type="file" name="file2"><br/>
<input type="file" name="file3"><br/>
<input type="file" name="file4"><br/>
<input type="file" name="file5"> <br/>
</td></tr>
<ww:submit value="提交"></ww:submit>
</table>
</form>
在另一个界面,用${param.category}得到,param指的是<c:param>标签[jstl] ,在xwork中对result可以不用做任何处理,只要告诉它下一个界面是什么就可以了!
其中:${param.categoryId}和${param.testId}是得到上个界面的值得!
2. 如果在两个页面传值,中间经过了一个java文件,那么可以通过xwork进行传值,具体做法如果下
jsp:
<c:url var="testContent" value="/admin/select_Test_category.action">
<c:param name="model.test_id" value="${test.testId}"/>
<c:param name="model.category_id" value="${test.categoryId}"/>
</c:url>
<a href="${testContent}">编辑</a>
xwork中:
<action name="select_Test_category" class="com.cool.lvjiachun.Select_Test_categoryAction">
<result name="success" type="dispatcher">
<param name="location">/cool/lvjiachun/test_category.jsp</param>
</result>
<result name="alone" type="dispatcher">
<param name="location">
/cool/lvjiachun/editor_test_category.jsp?model.category_id=${model.category_id}</param>
</result>
<interceptor-ref name="WSStack"/>
</action>
看一下result是怎么弄得吧,“?model.category_id=${model.category_id}”,${model.category_id}是第一个jsp“<c:paramname="model.test_id"value="${test.testId}"/>”
里的name,这样值在下一个界面就可以得到了
下一个jsp,也就是editor_test_category.jsp,
<ww:a href="admin/getTestList.action?model.category_id=${model.category_id}&id=${model.category_id}" value="返回">
返回
</ww:a>
这样就可以了!
3.如果要经过两个action,经过一个action后还要经过另一个action才能到下一个jsp,后一个action需要jsp界面的数据,那么可以用重定向redirect,这样就可以达到你想要的结果!(也可以不用,但要通过数据库在去查数据,这样很耗费时间,也麻烦)
例如:
jsp:
<ww:form action="/admin/addTestCategory.action" method="post" validate="true">
<ww:textfield label="添加分类" name="test.testName" required="true"/>
<ww:submit value="添加"></ww:submit>
<ww:url id="listlink" namespace="/admin" action="getTestList" method="getList"></ww:url>
<ww:hidden name="test.categoryId" value="${param.id}"></ww:hidden>
</ww:form>
xwork中:
<action name="addTestCategory" class="com.dream.action.TestCategoryAction" method="insert">
<external-ref name="testcategoryDAO">testcategoryDAOProxy</external-ref>
<result name="success" type="redirect">
<param name="location">/admin/getTestList.action?id=${test.categoryId}&model.category_id=${test.categoryId}</param>
</result>
<result name="input" type="redirect">
<param name="location">/admin/getTestList.action?model.category_id=${test.categoryId}&id=${test.categoryId}</param>
</result>
<interceptor-ref name="WSStack"/>
<interceptor-ref name="validationWorkflowStack"/>
</action>
“${param.id}”,看到了吧,它就是1的方法得到的!!!
其实这些也是经过才做到的,发在这里有兴趣的大家分享一下,也许我描述不对,但我相信大家看例子也可以看懂得!如果有什么不对的地方,也请前辈们谅解并给予纠正!
分享到:
相关推荐
此外,对于初学者,建议从以下几个方面入手: - 分析Action的生命周期,了解何时创建、何时销毁,以及如何执行Action方法。 - 研究拦截器的实现,了解如何自定义拦截器并将其添加到配置中。 - 学习OGNL的用法,理解...
4. **Result**:定义了Action执行后的输出,可以是跳转到另一个页面,也可以是返回JSON或XML数据。 5. **ActionMapping**:包含了Action的配置信息,如Action类、方法、结果等。 通过分析XWork的源码,开发者可以更...
在提供的"简单struts登录界面"中,我们可以通过两个JSP页面、一个Action和一个FormAction来理解Struts的基本工作流程。 首先,我们来看JSP页面。在Struts中,JSP主要负责展示视图部分。这里有两个JSP页面,一个是...
本文将详细介绍在 JSP 和 Struts2 中如何在 Action 类中使用 Session,包括两种主要的方法:通过 `ActionContext` 获取 Session 和实现 `SessionAware` 接口。 #### 一、通过 `ActionContext` 获取 Session 在 ...
在描述中提到的"简单的jsp页面",可能涉及到以下几个方面: 1. JSP(JavaServer Pages)是用于动态生成HTML、XML或其他格式文档的技术,通常用于视图层。在Struts中,JSP通常作为Result来显示用户界面。 2. 注册登录...
2. **配置文件**:主要有两个,一个是`struts.xml`,它是Struts2的主配置文件,用于定义Action类、结果页面、拦截器等;另一个是`web.xml`,负责设置Servlet容器的配置,如过滤器和监听器。 3. **Interceptor(拦截...
在Struts框架中,主要涉及以下几个关键知识点: 1. **Action类**:在Struts中,Action类是处理用户请求的核心组件。它实现了`com.opensymphony.xwork2.Action`接口,通常包含处理业务逻辑的方法。在这个登录系统中...
4. **JSP**:视图层主要由JSP页面构成,通过使用Struts标签库(Struts Tags)如、等,可以轻松地创建动态页面,同时与ActionForm进行数据交互。 5. **Tiles**:在更复杂的项目中,Struts还可以结合Tiles框架,实现...
这个应用可能包含以下几个部分: 1. **Action类**:如`HelloWorldAction.java`,实现简单的业务逻辑。 2. **配置文件**:如`struts.xml`,定义Action的映射和结果页面。 3. **JSP页面**:如`hello.jsp`,展示Action...
9. **commons-fileupload.jar**和**commons-io.jar**:这两个库分别提供了文件上传和I/O操作的支持,对于处理Web表单中的文件上传功能至关重要。 10. **struts2-config-browser-plugin.jar**:这个插件提供了一个...
7. **Result类型**:Action执行后的结果通常会定向到一个JSP页面或者其他的资源,这由Result类型决定。Struts2提供了多种Result类型,如dispatcher(用于转发到JSP)、stream(用于下载文件)等。 8. **插件体系**...
1. 创建两个JSP页面,如`hello.jsp`和`success.jsp`,分别作为请求的入口和结果展示。 2. 编写一个Java类作为动作类,遵循POJO(Plain Old Java Object)规范,这个类将包含处理请求的方法。 3. 在`struts.xml`中...
2. **配置文件**:Struts2的配置主要通过两个文件进行,即`struts.xml`和`web.xml`。`struts.xml`负责定义Action、结果类型、拦截器栈等,而`web.xml`则进行过滤器配置,将所有HTTP请求转发到Struts2框架。 3. **...
在本例中,有两个JSP页面:一个是登录表单页面(例如`login.jsp`),另一个是登录成功或失败后的结果页面(例如`success.jsp`或`error.jsp`)。 5. **ActionMapping和ActionInvocation**:ActionMapping表示Action...
6. **创建JSP页面**:创建两个JSP页面,一个用于展示登录表单(login.jsp),另一个用于显示登录成功的消息(success.jsp)。在login.jsp中,使用Struts2的标签库来创建表单并提交数据: ```jsp ... ...
4. **结果配置**: 定义了两个结果,分别对应成功后的不同页面跳转。 ```xml /jsp/paper/borrowcirculation/upFile.jsp /jsp/paper/borrowcirculation/upFileView.jsp ``` **总结** 本文...
目前分为Xwork和WebWork2两个项目。Xwork是一个简单的Command模式实现,提供前端拦截器、运行时表单属性验证、类型转换、强大的表达式语言OGNL以及IoC容器等功能。WebWork2基于Xwork,处理HTTP响应和请求,支持多...
通过分析和实践这个示例,你可以学习到如何创建Action、编写配置文件、设置拦截器以及如何在JSP页面中展示数据。这对于初学者来说是一个很好的起点,能够帮助理解Struts 2的基本架构和工作流程。同时,随着深入学习...
- **从技术角度比较Struts 1.1与WebWork 2**:比较了这两个流行框架之间的差异。 - **WebWork的项目资源**:提供了一些有用的链接和资源,帮助开发者更好地了解和使用WebWork。 - **参考资料**:列出了一些官方文档...