Struts2整合AJAX有2种方式:

  • 使用type="stream"类型的<result>
  • 使用JSON插件

使用type="stream"类型的<result>  获取text

前端

  <body>
<form>
学号:<input type="text" id="no"><br />
姓名:<input type="text" id="name"><br />
<button type="button" id="btn">查询成绩</button>
</form>
<p id="score"></p> <script src="js/jquery-3.4.1.min.js"></script>
<script>
$("#btn").click(function () {
$.ajax({
url:"HandlerAction",
type:"get",
data:{"no":$("#no").val(),"name":$("#name").val()},
dataType:"text",
error:function () {
console.log("ajax请求失败!")
},
success:function (data) {
$("#score").text(data);
}
})
});
</script>
</body>

url要和struts.xml中action的name、包的namespace对应。

action

public class HandlerAction extends ActionSupport {
private int no;
private String name;
private InputStream inputStream;
public int getNo() {
return no;
} public void setNo(int no) {
this.no = no;
} public String getName() {
return name;
} public void setName(String name) {
this.name = name;
} public InputStream getInputStream() {
return inputStream;
} public void setInputStream(InputStream inputStream) {
this.inputStream = inputStream;
} @Override
public String execute() throws Exception {
//此处缺省连接数据库查询总分
String result = name + "同学,你的总分是:680";
//设置要返回的数据。我们传给浏览器的数据含有中文,需要设置utf-8编码,来解决中文乱码
inputStream=new ByteArrayInputStream(result.getBytes("utf-8"));
return SUCCESS;
}
}

前端向后台发送了2个字段:no、name

action需要设置2个同名的成员变量,并提供对应的getter、setter方法,才能接收到前端传来的数据。

需要一个InputStream类型的成员变量,并提供对应的getter、setter,用于向浏览器返回数据。

需要一个处理请求的方法(execute),设置返回给浏览器的数据。

struts.xml

<struts>
<package name="action" namespace="/" extends="struts-default">
<action name="HandlerAction" class="action.HandlerAction">
<result name="success" type="stream">
<!-- 设置返回给浏览器的数据类型 -->
<param name="contentType">text/html</param>
<!--指定获取InputStream的方法,getInputStream(),约定:去掉get,后面部分使用camel写法 -->
<param name="inputName">inputStream</param>
</result>

</action>
</package>
</struts>

流程分析

  • 前端向后台发送ajax请求,传递no、name2个字段
  • JVM创建action实例,调用no、name对应的setter方法把前端传过来的值赋给成员变量(会自动转换为目标类型),完成action的初始化
  • JVM调用action处理业务的方法execute,设置向浏览器返回的数据
  • JVM根据struts.xml中<result>指定的方法(getInputStream),获取InputSteam,将里面的数据传给浏览器。

使用type="stream"类型的<result>  获取json

前端

 <body>
<form>
学号:<input type="text" id="no"><br />
<button type="button" id="btn">查询学生信息</button>
</form>
<div id="show"></div> <script src="js/jquery-3.4.1.min.js"></script>
<script>
$("#btn").click(function () {
$.ajax({
url:"HandlerAction",
type:"post",
data:{"no":$("#no").val()},
dataType:"json",
error:function () {
console.log("ajax请求失败!")
},
success:function (data) {
$("#show").append("姓名:" + data.name+",");
$("#show").append("年龄:" + data.age+",");
$("#show").append("成绩:" + data.score+"。");
}
})
});
</script>
</body>

action

public class HandlerAction extends ActionSupport {
private int no;
private InputStream inputStream; public int getNo() {
return no;
} public void setNo(int no) {
this.no = no;
} public InputStream getInputStream() {
return inputStream;
} public void setInputStream(InputStream inputStream) {
this.inputStream = inputStream;
} @Override
public String execute() throws Exception {
//此处缺省连接数据库查询得到学生信息
Student student = new Student(1, "张三", 20, 100);
String jsonStr = JSON.toJSONString(student); //设置要返回的数据
inputStream=new ByteArrayInputStream(jsonStr.getBytes("utf-8"));
return SUCCESS;
}
}

使用了阿里的fastjson.jar,需要自己下载引入。

struts.xml

配置同上


使用JSON插件实现AJAX

前端

<body>
<form>
学号:<input type="text" id="no"><br />
<button type="button" id="btn">查询学生信息</button>
</form>
<div id="show"></div> <script src="js/jquery-3.4.1.min.js"></script>
<script>
$("#btn").click(function () {
$.ajax({
url:"HandlerAction",
type:"post",
data:{"no":$("#no").val()},
dataType:"json",
error:function () {
console.log("ajax请求失败!")
},
success:function (data) {
$("#show").append("姓名:" + data.student.name+",");
$("#show").append("年龄:" + data.student.age+",");
$("#show").append("成绩:" + data.student.score+"。");
}
})
});
</script>
</body>

action

public class HandlerAction extends ActionSupport {
private int no;
private Student student;
public int getNo() {
return no;
} public void setNo(int no) {
this.no = no;
} public Student getStudent() {
return student;
} public void setStudent(Student student) {
this.student = student;
} @Override
public String execute() throws Exception {
//此处缺省连接数据库查询得到学生信息
student = new Student(1, "张三", 20, 100);
return SUCCESS;
}
}

需要设置同名的成员变量,并提供getter、setter方法,来接收前端传来的数据。

此种方式是由JSON插件把action对象序列化为一个JSON格式的字符串,传给浏览器。浏览器可以直接访问action的所有成员变量(实质是调用对应的getter方法)。

我们只需要把ajax要请求的数据封装为action的成员变量,并提供对应的getter、setter方法。需要在主调方法(execute)的return语句之前对请求的数据赋值。

success:function (data) {
$("#show").append("姓名:" + data.student.name+",");
$("#show").append("年龄:" + data.student.age+",");
$("#show").append("成绩:" + data.student.score+"。");
}

浏览器接受到的数据data本身就是action实例,可通过.访问成员变量。

struts.xml

<struts>
<package name="example" namespace="/" extends="json-default">
<action name="HandlerAction" class="action.HandlerAction">
<!--type="json"的result,可以缺省name属性,当然写上也行-->
<result type="json">
<param name="noCache">true</param>
<!-- 设置返回给浏览器的数据类型 -->
<param name="contentType">text/html</param>
</result>
</action>
</package>
</struts>

json-default包继承了struts-default包的配置,所以不必再继承struts-default。

说明

需要手动添加JSON插件 struts2-json-plugin.jar 。

上面的压缩包含有struts的所有jar包,其中就包括了struts2-json-plugin.jar。

下面的压缩包只有struts核心的8个jar包。

Struts2 处理AJAX请求的更多相关文章

  1. extjs ajax请求与struts2进行交互

    sencha extjs 5 增加一个struts2的配置,这样可以在设置好前台布局之后,与后台交互获取数据显示.现在有一个问题是struts2对于url的跳转action支 持比较良好,但是对于像E ...

  2. Struts2处理(jQuery)Ajax请求

    1. Ajax     Ajax(Asynchronous JavaScript and XML,异步JavaScript和XML)时一种创建交互式网页应用的网页开发技术,它并不是一项新的技术,其产生 ...

  3. Struts2 在登录拦截器中对ajax请求的处理

    前言: 由于ajax请求不像http请求,可以直接进行页面跳转,你返回的所有东西,ajax都只会识别为一个字符串. 之前尝试的方法是在拦截器中返回一个标识给ajax,然后再在每一个ajax请求成功之后 ...

  4. struts2响应AJAX

    1发送ajax请求使用stream进行响应 Result的type属性的stream取值. 1.1定义Action public class UserAction { private String u ...

  5. 关于struts2中action请求会执行两次的问题

    关于struts2中action请求会执行两次的问题     在struts2中发现,调用action中的方法,方法会被执行两次,后来发现调用的方法是get开头的,把它改为其他名称开头的后,就不会执行 ...

  6. Struts2之ajax初析

    Web2.0的随波逐流,Ajax那是大放异彩,Struts2框架自己整合了对Ajax的原生支持(struts 2.1.7+,之前的版本可以通过插件实现),框架的整合只是使得JSON的创建变得异常简单, ...

  7. Jquery progressbar通过Ajax请求获取后台进度演示

    项目源代码下载:http://download.csdn.net/detail/nuptboyzhb/6262253 1.简介 本文主要演示Jquery progressbar的进度条功能.js通过a ...

  8. Struts2结合Ajax实现登录

    前言:Struts2作为一款优秀的MVC框架,和Ajax结合在一起,用户就会有良好的体验,本篇博文我们来模拟一个简单的登录操作,实现Ajax的异步请求,其中Struts2进行的是链接处理,Action ...

  9. Struts2与Ajax数据交互

    写在前面: ajax请求在项目中常常使用,今天就平时掌握的总结一下,关于使用ajax请求到Struts2中的action时,前台页面与后台action之间的数据传递交互问题. 这里我主要记录下自己所掌 ...

随机推荐

  1. Apollo安装教程

    最近一直在研究Apollo的安装问题,浪费了几天时间,所有特意来记录一下安装心得. UBUNTU 14.04安装 这个我是把自己的笔记本全部转换为ubuntu系统,操作相对简单,大家可以自行查找,另外 ...

  2. springmvc validator和springContext validator的区别

    1.springContext validator 依赖于代理实现 MethodValidationInterceptor Set<ConstraintViolation<Object&g ...

  3. 后台怎么区分接口要写在哪个service类中呢(根据service服务区分)

    1,明确页面要实现什么功能,则页面对应的controller要写对应的controller方法 2,这个功能最终要由谁实现完成,在对应的service中药实现这个功能 3,这个接口的实现就写在最终完成 ...

  4. 动手实现CapsNet系列——1 概述

    Geoffrey Hinton是深度学习的开创者之一,反向传播等神经网络经典算法发明人,他在17年年底和他的团队发表了两篇论文,介绍了一种全新的神经网络,这种网络基于一种称为胶囊(Capsule)的结 ...

  5. 寒假安卓app开发学习记录(3)

    今天终于开始正式的安卓软件开发学习.开始用了大约一个小时的时间把创建第一个软件的学习视频观看了一下.跟着视频一边学习一边操作. 首先是创建项目,创建的过程和之前创建Java项目的过程相似.先给app起 ...

  6. 每天进步一点点------Altium Designer集成库简介及创建

    一.集成库概述    Altium Designer 采用了集成库的概念.在集成库中的元件不仅具有原理图中代表元件的符号,还集成了相应的功能模块.如Foot Print 封装,电路仿真模块,信号完整性 ...

  7. session跨域共享问题解决方案

    在讨论 session 跨域共享问题之前,我们首先要了解 session 做了什么,没做什么 1.HTTP是无状态的,也就是说服务器不知道谁访问过他,但是有时间,又需要我们去保留这个状态比如说用户的登 ...

  8. PowerDesigner 16.5安装、激活

    PowerDesigner安装 PowerDesigner激活 PowerDesigner运行

  9. Java生鲜电商平台-生鲜电商高并发下的接口幂等性实现与代码讲解

    Java生鲜电商平台-生鲜电商高并发下的接口幂等性实现与代码讲解 说明:Java生鲜电商平台-生鲜电商高并发下的接口幂等性实现与代码讲解,实际系统中有很多操作,是不管做多少次,都应该产生一样的效果或返 ...

  10. C#面向对象三大特性:继承

    什么是继承 定义:继承是面向对象编程语言中的一个重要特性,当一个类A能够获取另一个类B中所有非私有的数据和操作的定义作为自己的部分或全部成分时,就称这两个类之间具有继承关系.被继承的类B称为父类或基类 ...