struts2接受ajax请求,Struts2 处理AJAX请求(示例代码)

Struts2整合AJAX有2种方式:

使用type="stream"类型的

使用JSON插件

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

前端

学号:
姓名:

查询成绩

$("#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);

}

})

});

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

action

public class HandlerAction extendsActionSupport {private int no;

private String name;

private InputStream inputStream;public intgetNo() {returnno;

}public void setNo(intno) {this.no =no;

}publicString getName() {returnname;

}public voidsetName(String name) {this.name =name;

}publicInputStream getInputStream() {returninputStream;

}public voidsetInputStream(InputStream inputStream) {this.inputStream =inputStream;

}

@Overridepublic String execute() throwsException {//此处缺省连接数据库查询总分

String result = name + "同学,你的总分是:680";//设置要返回的数据。我们传给浏览器的数据含有中文,需要设置utf-8编码,来解决中文乱码

inputStream=new ByteArrayInputStream(result.getBytes("utf-8"));returnSUCCESS;

}

}

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

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

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

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

struts.xml

text/html

inputStream

流程分析

前端向后台发送ajax请求,传递no、name2个字段

JVM创建action实例,调用no、name对应的setter方法把前端传过来的值赋给成员变量(会自动转换为目标类型),完成action的初始化

JVM调用action处理业务的方法execute,设置向浏览器返回的数据

JVM根据struts.xml中指定的方法(getInputStream),获取InputSteam,将里面的数据传给浏览器。

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

前端

学号:

查询学生信息

$("#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+"。");

}

})

});

action

public class HandlerAction extendsActionSupport {private intno;privateInputStream inputStream;public intgetNo() {returnno;

}public void setNo(intno) {this.no =no;

}publicInputStream getInputStream() {returninputStream;

}public voidsetInputStream(InputStream inputStream) {this.inputStream =inputStream;

}

@Overridepublic String execute() throwsException {//此处缺省连接数据库查询得到学生信息

Student student = new Student(1, "张三", 20, 100);

String jsonStr= JSON.toJSONString(student);//设置要返回的数据

inputStream=new ByteArrayInputStream(jsonStr.getBytes("utf-8"));returnSUCCESS;

}

}

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

struts.xml

配置同上

使用JSON插件实现AJAX

前端

学号:

查询学生信息

$("#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+"。");

}

})

});

action

public class HandlerAction extendsActionSupport {private int no;

private Student student;public intgetNo() {returnno;

}public void setNo(intno) {this.no =no;

}publicStudent getStudent() {returnstudent;

}public voidsetStudent(Student student) {this.student =student;

}

@Overridepublic String execute() throwsException {//此处缺省连接数据库查询得到学生信息

student = new Student(1, "张三", 20, 100);returnSUCCESS;

}

}

需要设置同名的成员变量,并提供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

true

text/html

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

254c79a95db246d3866f857e6b918053.jpg

说明

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

b251edb6a54a45fcb12935c48b7d735c.jpg

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

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

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值