日期:2014-05-16  浏览次数:20390 次

Struts2中JSON插件的使用及出现的问题

? ? ? ?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
          });