日期:2014-05-16 浏览次数:20493 次
? ? ? ?Struts2提供了对Ajax的支持,其中JSON是Ajax插件的一种,该插件将Action属性直接序列化为JSON对象后返回给客户端,从而使客户端页面可以直接访问到Action属性。
? ? ? ?在Struts2中使用JSON插件,首次将json插件包导入进去,接着实现Action逻辑,在struts.xml中配置该Action,然后实现JSP页面。下面来实现一个小例子,来完成这三个步骤。
1、实现Action逻辑
一个表单,有三个表单域,对应于三个请求参数,因此在Action中用三个相应的属性来封装这三个参数。Action的实现类如下:
?
package lee;
import java.util.HashMap;
import java.util.Map;
import javax.management.loading.PrivateClassLoader;
import com.opensymphony.xwork2.Action;
import com.opensymphony.xwork2.ActionContext;
import com.sun.org.apache.bcel.internal.generic.NEW;
import org.apache.struts2.json.annotations.JSON;
//import org.apache.struts2.json.*;
public class JSONExample {
private int[] ints={10,20};
private Map<String,String> map = new HashMap<String,String>();
private String customName="顾客";
private String field1;
private transient String field2;
private String field3;
public String execute(){
map.put("name", "wo");
return Action.SUCCESS;
}
@JSON(name="newName")
public Map getMap(){
return this.map;
}
public void setCustomName(String customName) {
this.customName = customName;
}
public String getCustomName() {
return customName;
}
public void setField1(String field1) {
this.field1 = field1;
}
public String getField1() {
return field1;
}
public void setField2(String field2) {
this.field2 = field2;
}
public String getField2() {
return field2;
}
public void setField3(String field3) {
this.field3 = field3;
}
public String getField3() {
return field3;
}
}
?
? ?上面代码中使用了JSON注释,指定了name属性,作用于下面所以的getter方法,只要属性的getter方法在注释下,则JSon就会返回给客户端。
2、在struts2.xml中配置Action
<package name="example" extends="json-default">
<action name="JSONExample" class="lee.JSONExample">
<result type="json"/>
</action>
</package>
?
?
?JSON插件提供一种名为json的ResultType,一旦为某个Action指定了类型为json的result,就不不要再映射到任何的物理视图。因为JSON插件会负责将Action里的状态信息序列化成JSON格式的字符串,并将该字符串返回给客户端页面。
?配置时需注意:a 配置strut.i18n.encoding时,编码格式要改为UTF-8编码,因为Ajax的post请求是以UTF-8的方式进 ? ? ? ? ? ? ? ? ? ? ? ? ?行编码的。
? ? ? ? ? ? ? ? ? ? ? b 配置包时,要继承json-default包,因为只有此包里才定义了json结果类型,可在json插件包里找到 ? ? ? ? ? ? ? ? ? ? ? ? ? ?struts-plugin.xml查看里面json-default包的定义,该包实际上继承了default包
3、实现JSP页面
为方面Ajax交互,我们使用javascript的一个框架Prototype.js.同时还要用json2.js库,用于将JSON格式字符串转换成JSON对象。下面是JSP页面:
?
<%@ page language="java" import="java.util.*" pageEncoding="GBK"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<base href="<%=basePath%>">
<title>My JSP 'jsonDemo.jsp' starting page</title>
<meta http-equiv="pragma" content="no-cache">
<meta http-equiv="cache-control" content="no-cache">
<meta http-equiv="expires" content="0">
<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
<meta http-equiv="description" content="This is my page">
<!--
<link rel="stylesheet" type="text/css" href="styles.css">
-->
<script type="text/javascript" src=json2.js></script>
<script type="text/javascript" src=prototype.js></script>
<script type=text/javascript>
function gotClick(){
var url='JSONExample.action';
var params=Form.serialize('form1');
var myAjax = new Ajax.Request(url,{
method:'post',
parameters:params,
onComplete:processResponse,
asynchronous:true
});