博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
使用stream类型的Result实现Ajax
阅读量:6616 次
发布时间:2019-06-24

本文共 3356 字,大约阅读时间需要 11 分钟。

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

例如下面做一个非常简单的Ajax登录示例,浏览者输入用户名、密码之后,我们让他以异步方式来提交请求,而Struts 2Action则直接输出登录结果——无须使用额外的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大致相同,同样提供了userpass两个属性来封装用户的请求参数,并为这两个属性提供settergetter方法。但这个Action与普通Action也略有差别,它提供了一个返回二进制流的方法:getResult()——如上面的Action类中粗体字代码所示。

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

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 2Ajax支持。

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

 

本文转自 51CTO博客,原文链接:http://blog.51cto.com/javaligang/895034 ,如需转载请自行联系原作者

你可能感兴趣的文章
Intercom的持续部署实践:一天部署100次,1次10分钟
查看>>
Windows I/O模型、同步/异步、阻塞/非阻塞
查看>>
SpringBoot权限控制
查看>>
阿里云中间件技术 促进互联网高速发展
查看>>
智能时代悄然到来 物联网称王将引爆传感器产业
查看>>
物理隔离计算机被USB蜜蜂刺破 数据通过无线信号泄露
查看>>
利用一点机器学习来加速你的网站
查看>>
中国域名现状:应用水平较低,安全仍存隐患
查看>>
Java中HashMap的原理分析
查看>>
React Native入门项目与解析
查看>>
云计算:大势所趋 你准备好了么?
查看>>
数据资产的运营商--天市大数据交易平台
查看>>
中小企业如何成功转型跨境电商
查看>>
java中文乱码解决之道(二)—–字符编码详解:基础知识 + ASCII + GB**
查看>>
《ANTLR 4权威指南》——2.5 语法分析树监听器和访问器
查看>>
02_JNI中Java代码调用C代码,Android中使用log库打印日志,javah命令的使用,Android.mk文件的编写,交叉编译...
查看>>
TIOBE 2016 年 5 月编程语言排行榜:Ruby 排名创历史新高
查看>>
《深入理解Elasticsearch(原书第2版)》一1.1.1 熟悉Lucene
查看>>
这些国货,在阿里平台上被美国剁手党抢疯了
查看>>
《Excel 职场手册:260招菜鸟变达人》一第 2 招 常用快捷键Windows与Mac对照
查看>>