前面介绍过Struts 2支持一种stream类型的Result,这种类型的Result可以直接向客户端浏览器生成二进制响应、文本响应等。那么我们就可让Struts 2的Action来直接生成文本响应,接下来在客户端页面动态加载该响应即可。

例如下面做一个非常简单的Ajax登录示例,浏览者输入用户名、密码之后,我们让他以异步方式来提交请求,而Struts 2的Action则直接输出登录结果——无须使用额外的JSP页面。下面是本示例的Action类代码。

程序清单:codes\04\4.6\streamAjax\WEB-INF\src\org\crazyit\app\action\LoginAction.java

  1. public class LoginAction
  2. implements Action
  3. {
  4. //封装请求参数的两个属性
  5. private String user;
  6. private String pass;
  7. //封装输出结果的二进制流
  8. private InputStream inputStream;
  9. //省略user属性的setter和getter方法
  10. ...
  11. //省略pass属性的setter和getter方法
  12. ...
  13. public InputStream getResult()
  14. {
  15. return inputStream;
  16. }
  17. public String execute()
  18. throws Exception
  19. {
  20. //判断用户名、密码,生成对应的响应
  21. inputStream = user.equals("crazyit.org") && pass.equals("leegang")
  22. ? new ByteArrayInputStream("恭喜你,登录成功!"
  23. .getBytes("UTF-8"))
  24. : new ByteArrayInputStream("对不起,用户名、密码不匹配!"
  25. .getBytes("UTF-8"));
  26. return SUCCESS;
  27. }
  28. }

上面的Action与普通登录Action大致相同,同样提供了user、pass两个属性来封装用户的请求参数,并为这两个属性提供setter和getter方法。但这个Action与普通Action也略有差别,它提供了一个返回二进制流的方法:getResult()——如上面的Action类中粗体字代码所示。

getResult()方法的返回的二进制流将会直接输出给浏览者——这将会使用stream类型的Result来完成,而上面的execute方法将会根据浏览者输入的user、pass请求参数来决定生成怎样的响应。

在struts.xml文件中配置该Action,配置片段如下。

程序清单:codes\04\4.6\streamAjax\WEB-INF\src\struts.xml

  1. <action name="loginPro" class="org.crazyit.app.action.LoginAction">
  2. <result name="success" type="stream">
  3. <!-- 指定stream生成的响应数据的类型 -->
  4. <param name="contentType">text/html</param>
  5. <!-- 指定由getResult()方法返回输出结果的InputStream -->
  6. <param name="inputName">result</param>
  7. </result>
  8. <!-- 定义一个名为login的结果 -->
  9. <result name="login">/WEB-INF/content/login.jsp</result>
  10. </action>

提示:通过使用stream类型的Result,Strut 2可以无需JSP视图页面,直接在Action向浏览者生成指定的响应。

接下来只要定义一个登录页面,该页面向上面的loginPro Action发送异步请求,并动态加载该Action送回来的响应即可。

为了简单起见,我们此处不会去做创建XMLHttpRequest对象、发送异步请求这些烦琐的步骤,此处将直接借助于jQuery这个Ajax库来发送异步请求。页面代码如下。

程序清单:codes\04\4.6\streamAjax\WEB-INF\content\login.jsp

  1. <%@ page contentType="text/html; charset=GBK" language="java" errorPage="" %>
  2. <%@ taglib prefix="s" uri="/struts-tags" %>
  3. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
  4. "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
  5. <html xmlns="http://www.w3.org/1999/xhtml">
  6. <head>
  7. <title>使用JSON插件</title>
  8. <script src="${pageContext.request.contextPath}/jquery-1.4.4.min.js"
  9. type="text/javascript">
  10. </script>
  11. </head>
  12. <body>
  13. <s:form id="loginForm">
  14. <s:textfield name="user" label="用户名"/>
  15. <s:textfield name="pass" label="密码"/>
  16. <tr><td colspan="2">
  17. <input id="loginBn" type="button" value="提交"/>
  18. </td></tr>
  19. </s:form>
  20. <div id="show" style="display:none;">
  21. </div>
  22. <script type="text/javascript">
  23. //为id为loginBn的按钮绑定事件处理函数
  24. $("#loginBn").click(function()
  25. {
  26. //指定向loginPro发送请求,以id为loginForm表单里各表单控件作为请求参数
  27. $.get("loginPro" , $("#loginForm").serializeArray() ,
  28. //指定回调函数
  29. function(data , statusText)
  30. {
  31. $("#show").height(80)
  32. .width(300)
  33. .css("border" , "1px solid black")
  34. .css("background-color" , "#efef99")
  35. .css("color" , "#ff0000")
  36. .css("padding" , "20px")
  37. .empty();
  38. $("#show").append("登录结果:" + data + "<br />");
  39. $("#show").show(2000);
  40. },
  41. //指定服务器响应为html
  42. "html");
  43. });
  44. </script>
  45. </body>
  46. </html>

上面的程序中粗体字代码正是通过jQuery发送异步请求的代码。在浏览器中浏览该页面,并输入合适的用户名、密码,然后登录系统,将可以看到如图4.34所示结果。

除此之外,Struts 2.2还提供了一个JSON插件,通过该插件能更简单地完成Ajax开发,下面主要以JSON插件为例来介绍Struts 2的Ajax支持。

提示:jQuery是一个非常优秀的、轻量级Ajax函数库,它不仅提供了大量方便的工具函数,而且对Ajax的支持也是既简单、又强大。如果读者希望获得更多关于jQuery的知识,请参考疯狂Java体系的《疯狂Ajax讲义》。

使用stream类型的Result实现Ajax相关推荐

  1. Redis数据类型之stream类型

    介绍 主要用于消息队列(MQ,Message Queue),Redis 本身是有一个 Redis 发布订阅 (pub/sub) 来实现消息队列的功能,但它有个缺点就是消息无法持久化,如果出现网络断开. ...

  2. 数组类型参数传递问题:$.ajax传递数组的traditional参数传递必须true

    数组类型参数传递问题:$.ajax传递数组的traditional参数传递必须true 转载自:https://www.cnblogs.com/goloving/p/7676811.html 数组类型 ...

  3. Jquery ajax 返回string类型加result.d原因

    啥叫异步,啥叫Ajax.咱不谈啥XMLHTTPRequest.通俗讲异步就是前台页面javascript能调用后台方法.这样就达到了无刷新.所谓的Ajax.这里我们讲二种方法 方法一:(微软有自带Aj ...

  4. struts通过Ajax返回数据时,例如对象类型,没有执行Ajax的回调函数

    <result type="json"  name="success">                  <param name=" ...

  5. ajax传formdata类型的数据_JQuery.Ajax()的data参数类型

    假如现在有这样一个表单,是添加元素用的. 用户名: 手机号: 生日: 我们不想使用表单submit的方式添加这个元素,我们就想使用ajax提交. 以前我们是这样实现的: 1 2 3 4 5 6 7 8 ...

  6. php 与结合struts2,Struts2和Ajax数据交互示例详解

    前言 我们从Web 2.0的随波逐流,Ajax的大放异彩说起,Struts2框架自己整合了对Ajax的原生支持(struts 2.1.7+,之前的版本可以通过插件实现),框架的整合只是使得JSON的创 ...

  7. Struts2 Result详解

    1,Result原理 1) Result组件是Struts2中用于输出的组件,实际上就是Java代码. 2)Struts2中预制了10中类型的Result,这些Result什么在struts-defa ...

  8. Java框架之Struts2(六)

    一.OGNL表达式语言 Ognl Object Graphic Navigation Language(对象图导航语言),它是一种功能强大的表达式语言(Expression Language,简称为E ...

  9. Struts2学习笔记(十九) 验证码

    概述 验证码也是我们在web应用中经常要用到的功能.基本思路就是,我们在服务端动态的生一成张图片,然后将它输出到客户端.图片上包含一些字符信息,我们将这些字符信息事先保存在session中,那么客户端 ...

最新文章

  1. 深度学习环境配置指南:Pytorch、TensorFlow、Keras
  2. Rust 数据类型介绍
  3. srs-2-CentOS6 创建 Simple-Rtmp-Server
  4. oracle按时间导出,如何为Oracle导出文件加上时间戳
  5. docker启动报错  (iptables failed: iptables --wait -t nat -A DOCKER -p tcp -d 0/0 --dport 9876 -j DNAT --
  6. C++ 学习之旅(10)——static与extern
  7. 【数学期望】【LCA】【树形DP】树
  8. 架构师:我们需要顶层设计
  9. Molile App(HTTP/HTML)—Record and Analyze Traffic
  10. java解析xml串标签_Java反射解析XML字符串并封装到指定的JavaBean
  11. 网信办拟规定:平台未经用户同意不得强制订阅关注账号;Twitter回应大范围宕机;Krita 4.4.0发布|极客头条
  12. CS224N笔记——RNN和语言模型
  13. 偶极子阵列天线(带反射板)+单层天线罩
  14. 公民住宅权不可侵犯!为阻强拆致人重伤,属正当防卫
  15. android 电池检测软件,AccuBattery手机电池损耗检测软件
  16. LoadRunner11的安装、破解以及基本使用
  17. 有高血压的少碰这五种毒!它们的伤害悄无声息~
  18. Openstack基础环境交换机常用配置(CISCO 3750G为例).md
  19. 基于人脸识别的课堂签到管理系统2020,7,19
  20. i9502移植rom包进程记录

热门文章

  1. acer清理工具 clear下载_时秋极致清理大师app下载安装_时秋极致清理大师软件最新版免费下载...
  2. 测试MindMotion MM32F3277 MicroPython -2021-11-20新增PWM版本
  3. 第十五届全国大学生智能车东北赛区成绩
  4. ADA4530静电计放大器
  5. 基于STC8G1K08的实验电路板
  6. 低内阻的MOS管 4N04R7
  7. python中calendar怎么用_Python时间模块datetime、time、calendar的使用方法
  8. 光电编码器的原理及应用场合_光电传感器原理及应用
  9. office2003计算机考试,计算机考试Office2003应用.doc
  10. 请输入课程编号C语言,C语言 学生选课系统 程序