`
荷戟者
  • 浏览: 274513 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

Jsonplugin结合struts2使用说明

阅读更多

资料:http://clayz.iteye.com/blog/422125

配置中的参数含义:

 

root参数用于指定要序列化的根对象,如果省去这一配置,表示要序列化action中的所有属性

ignoreHierarchy false时表示要序列化根对象的所有基类

excludeProperties表示排除的序列化的属性

includeProperties表示哪些属性被序列化

 

Action配置:

 

<!-- jsonplugin的使用配置 --> 

        <!-- package要继承json-default 以加载json插件 --> 

        <action name="jsonAct" class="cn.enjoylife.prac.action.JsonAction"> 

            <result type="json"> 

                <!-- root参数用于指定要序列化的根对象,如果省去这一配置,表示要序列化action中的所有属性 --> 

                <param name="root">map</param> 

                <!-- ignoreHierarchy false时表示要序列化根对象的所有基类 --> 

                <param name="ignoreHierarchy">false</param> 

                <!-- 排除hello属性,使其不被序列化 --> 

                <param name="excludeProperties">hello</param> 

            </result> 

        </action>

 

JsonAction.java:

 

/**

 * @author Evan

 * 

 */ 

public class JsonAction extends ActionSupport { 

    private static final long serialVersionUID = 3870310687165227565L; 

    private int[] ints = { 100, 200 }; 

    private Map<String, Object> map = new HashMap<String, Object>(); 

    private String hello = "helloWorld"; 

    private String username = "evan";//没有getter方法,不会被序列化  

    private String password = "pwd"; 

    private String validateCode = "123456"; 

    public int[] getInts() { 

        return ints; 

    } 

    public void setInts(int[] ints) { 

        this.ints = ints; 

    } 

    @JSON(name="newMap")//重新命名  

    public Map<String, Object> getMap() { 

        return map; 

    } 

    public void setMap(Map<String, Object> map) { 

        this.map = map; 

    } 

    public String getHello() { 

        return hello; 

    } 

    public void setHello(String hello) { 

        this.hello = hello; 

    } 

    public void setUsername(String username) { 

        this.username = username; 

    } 

    @JSON(serialize=true)//这是默认值,可以省去  

    public String getPassword() { 

        return password; 

    } 

    public void setPassword(String password) { 

        this.password = password; 

    } 

    @JSON(serialize=false)//serialize参数为false,不会被序列化  

    public String getValidateCode() { 

        return validateCode; 

    } 

    public void setValidateCode(String validateCode) { 

        this.validateCode = validateCode; 

    } 

    @Override 

    public String execute() throws Exception { 

        map.put("info", "今天的雨真大啊!"); 

        return SUCCESS; 

    } 

} 

 

使用jquery操作返回的json串:

 

$(document).ready(function(){ 

    $.getJSON( 

        "./jsonAct.action",  

        function(data){ 

            alert(data.info); 

        } 

    ); 

});

 

Annotation:

 

  1. package com.zheshou.action;   
  2.   
  3. import javax.annotation.Resource;   
  4.   
  5. import org.apache.struts2.convention.annotation.Action;   
  6. import org.apache.struts2.convention.annotation.Namespace;   
  7. import org.apache.struts2.convention.annotation.ParentPackage;   
  8. import org.apache.struts2.convention.annotation.Result;   
  9. import com.opensymphony.xwork2.ActionSupport;   
  10. import com.zheshou.model.Dept;   
  11. import com.zheshou.model.User;   
  12. import com.zheshou.service.DeptService;   
  13. import com.alibaba.fastjson.JSON;   
  14.   
  15. @ParentPackage(value="json-default")   
  16. @Namespace(value="/")   
  17. public class SelectDeptAction extends ActionSupport {//2.ActionSupport必须有这个才行.但是可以不用Execute   
  18.        
  19.     private DeptService deptService;   
  20.        
  21.     private String beginTime;   
  22.     private String endTime;   
  23.     private String Emps;   
  24.     private String result;   
  25.        
  26.     public DeptService getDeptService() {   
  27.         return deptService;   
  28.     }   
  29.     @Resource(name="deptService")   
  30.     public void setDeptService(DeptService deptService) {   
  31.         this.deptService = deptService;   
  32.     }      
  33.        
  34.     public String getBeginTime() {   
  35.         return beginTime;   
  36.     }   
  37.   
  38.     public void setBeginTime(String beginTime) {   
  39.         this.beginTime = beginTime;   
  40.     }   
  41.   
  42.     public String getEndTime() {   
  43.         return endTime;   
  44.     }   
  45.   
  46.     public void setEndTime(String endTime) {   
  47.         this.endTime = endTime;   
  48.     }   
  49.   
  50.     public String getEmps() {   
  51.         return Emps;   
  52.     }   
  53.   
  54.     public void setEmps(String emps) {   
  55.         Emps = emps;   
  56.     }   
  57.     public String getResult() {   
  58.         return result;   
  59.     }   
  60.   
  61.     public void setResult(String result) {   
  62.         this.result = result;   
  63.     }   
  64.   
  65.     @Action(value="selectdept"  
  66.         ,results={@Result(   
  67.                 type="json"  
  68.                 ,params={"contentType","text/html","root","result"}//root<会带外引号>    
  69. //includeProperties Result不带字符引号   
  70. //excludeProperties 返回所有的属性   
  71.                     )}   
  72.                )   
  73.     public String execute(){   
  74.         //result= JSON.toJSONString(user).replaceAll("\"", "'");   
  75.         result=deptService.Select(Emps);   
  76.         System.out.print(result);   
  77.         return SUCCESS;   
  78.     }   
  79. }

***********************************************************************************

 

Struts 2中使用JSON Ajax支持

  JSON插件提供了一种名为jsonResultType,一旦为某个Action指定了一个类型为jsonResult,则该Result无需映射到任何视图资源。将下载到的jsonplugin-0.7.jar文件复制到Web应用的WEB-INF路径下,即可完成JSON插件的安装。

  JSON插件提供了一种名为jsonResultType,一旦为某个Action指定了一个类型为jsonResult,则该Result无需映射到任何视图资源。因为JSON插件会负责将Action里的状态信息序列化成JSON格式的数据,并将该数据返回给客户端页面的JavaScript

  简单地说,JSON插件允许我们在JavaScript中异步调用Action,而且Action不再需要使用视图资源来显示该Action里的状态信息,而是由JSON插件负责将Action里的状态信息返回给调用页面——通过这种方式,就可以完成Ajax交互。

  Struts2提供了一种可插拔方式来管理插件,安装Struts2JSON插件与安装普通插件并没有太大的区别,一样只需要将Struts2插件的JAR文件复制到Web应用的WEB-INF/lib路径下即可。

  安装JSON插件按如下步骤进行:

  (1)登陆http://code.google.com/p/jsonplugin/downloads/list站点,下载Struts2JSON插件的最新版本,当前最新版本是0.7,我们可以下载该版本的JSON插件。

  (2)将下载到的jsonplugin-0.7.jar文件复制到Web应用的WEB-INF路径下,即可完成JSON插件的安装。

  实现Actio逻辑

  假设wo,en输入页面中包含了三个表单域,这三个表单域对于三个请求参数,因此应该使用Action来封装这三个请求参数。三个表单域的name分别为field1field2field3

  处理该请求的Action类代码如下:  

public class JSONExample 
  
{ 
  //封装请求参数的三个属性 

  private String field1; 
  
private transient String field2; 
  
private String field3; 
  //封装处理结果的属性 

  private int[] ints = {10, 20}; 
  
private Map map = new HashMap(); 
  
private String customName = "custom"; 
  //三个请求参数对应的settergetter方法 

  public String getField1() 
  
{ 
  
return field1; 
  
} 
  
public void setField1(String field1) 
  
{ 
  
this.field1 = field1; 
  
} 
  //此处省略了field1field2两个字段的settergetter方法 

  ... 
  //封装处理结果的属性的settergetter方法 

  public int[] getInts() 
  
{ 
  
return ints; 
  
} 
  
public void setInts(int[] ints) 
  
{ 
  
this.ints = ints; 
  
} 
  
public Map getMap() 
  
{ 
  
return map; 
  
} 
  
public void setMap(Map map) 
  
{ 
  
this.map = map; 
  
} 
  //使用注释语法来改变该属性序列化后的属性名 

  @JSON(name="newName") 
  
public String getCustomName() 
  
{ 
  
return this.customName; 
  
} 
  
public String execute() 
  
{ 
  
map.put("name", "yeeku"); 
  
return Action.SUCCESS; 
  
} 
  }

  在上面代码中,使用了JSON注释,注释时指定了name域,name域指定Action属性被序列化成JSON对象的属性名。除此之外,JSON注释还支持如下几个域:

  

      serialize:设置是否序列化该属性

  deserialize:设置是否反序列化该属性。

  format:设置用于格式化输出、解析日期表单域的格式。例如"yyyy-MM-dd'T'HH:mm:ss"

  配置该Action与配置普通Action存在小小的区别,应该为该Action配置类型为jsonResult。而这个Result无需配置任何视图资源。

  配置该Actionstruts.xml文件代码如下: 

?xml version="1.0" encoding="GBK"? 
!DOCTYPE struts PUBLIC 
"-//Apache Software Foundation//DTD Struts Configuration 2.0//EN" 
"http://struts.apache.org/dtds/struts-2.0.dtd"
 

struts 
constant name="struts.i18n.encoding" value="UTF-8"/ 
package name="example" extends="json-default" 
action name="JSONExample" class="lee.JSONExample" 
result type="json"/ 
/action 
/package 
/struts>  

  在上面配置文件中有两个值得注意的地方:

  第一个地方是配置struts.i18n.encoding常量时,不再是使用GBK编码,而是UTF-8编码,这是因为AjaxPOST请求都是以UTF-8的方式进行编码的。

  第二个地方是配置包时,自己的包继承了json-default包,而不再继承默认的default包,这是因为只有在该包下才有json类型的Result

 

Apache提供的一个插件包,可以把 Action中的数据以 JSON做个封装然后返回。

它会将整个 action中的变量转化为 JSON数据 (根对象在 JSON中数据添加一个 ”root”标识 )。如果要使用它, Action必须遵循以下几点:

·         返回的页面类型中 ”content-type”必须是 ”application/json”.(这个已经 Internet Community采用 ).

·         JSON内容必须是符合格式要求的 .

·         Action field必须有 public get方法 .(是不是没有 set方法就不会将 field添加到 JSON数据中,有待验证 ).,可以没有set方法

·         它支持的类型有 : 基本类型 (int,long...String), Date, List, Map, Primitive Arrays, 其它 class, 对象数组 .

·          JSON中任何的 Object会被封装在 list map中,数据会被封装程 Long,如果是含有的数据则会被封装程 Double,数组会被封装程 List.

下面给出 JSON的数据格式:

Json代码 

1.  <span style="font-family: arial,helvetica,sans-serif;">{  

2.      "doubleValue"10.10,  

3.      "nestedBean": { "name""Mr Bean" },  

4.      "list": ["A"1020.20, { "firstName""El Zorro" }],  

5.      "array": [1020]  

6.  }</span>  

 

这个插件支持以下几个注释 :

 

注释名

简介

默认值

序列化

反序列化

name

配置 JSON  name

empty

yes

no

serialize

 serialization 

true

yes

no

deserialize

 deserialization 

true

no

yes

format

格式化 Date 字段

"yyyy-MM-dd'T'HH:mm:ss"

yes

yes

 

可以通过配置来显示指出要放在 JSON field,其中有个自己的验证规则需要研究 .

Xml代码 

1.  <!-- Result fragment -->  

2.  <result type="json">  

3.      <param name="excludeProperties">  

4.          login.password,  

5.          studentList.*".sin  

6.      </param>  

7.  </result>  

8.    

9.  <!-- Interceptor fragment -->  

10. <interceptor-ref name="json">  

11.     <param name="enableSMD">true</param>  

12.     <param name="excludeProperties">  

13.         login.password,  

14.         studentList.*".sin  

15.     </param>  

16. </interceptor-ref>  

 

根对象

Xml代码 

1.  <result type="json">  

2.      <param name="root">  

3.          person.job  

4.      </param>  

5.  </result>  

 

也可以使用拦截器配置操作父对象

Xml代码 

1.  <interceptor-ref name="json">  

2.      <param name="root">bean1.bean2</param>  

3.  </interceptor-ref>  

 

 JSON数据用注释封装

如果 wrapWithComments 设置为 true( 默认值为 false) ,则生成的 JSON 数据会变成这样

Json代码 

1.  /* {  

2.      "doubleVal"10.10,  

3.      "nestedBean": { "name""Mr Bean" },  

4.      "list": ["A"1020.20, { "firstName""El Zorro" }],  

5.      "array": [1020]  

6.  } */  

 

这样做可以避免 js中一些潜在的风险,使用时需要 :Var responseObject = eval("("+data.substring(data.indexOf(""/"*")+2, data.lastIndexOf(""*"/"))+")");

 

父类

“root”对象中父类的 field不会(会?) 默认存放到 JSON数据中,如果不想这样做,需要在配置时指定 ignoreHierarchy  false:

Xml代码 

1.  <result type="json">  

2.      <param name="ignoreHierarchy">false</param>  

3.  </result>  

 

枚举类型

默认处理枚举类型时,会被处理成 JSON数据中 name等于枚举中 value value等于枚举中 name.

Java代码 

1.  public enum AnEnum {  

2.      ValueA,  

3.      ValueB  

4.  }  

 

JSON: "myEnum":"ValueA"

 

如果在处理枚举类型时,在 xml中配置了 enumAsBean,则会被当作一个 Bean处理,在 JSON数据中会有一个特别的属性 ”_name”值为 name().这个枚举中的所有属性都会被处理 .

Java代码 

1.  public enum AnEnum {  

2.      ValueA("A"),  

3.      ValueB("B");  

4.    

5.      private String val;  

6.    

7.      public AnEnum(val) {  

8.          this.val = val;  

9.      }  

10.   

11.     public getVal() {  

12.        return val;  

13.     }  

14. }  

 

JSON: myEnum: { "_name": "ValueA", "val": "A" }

 

Xml中配置 :

Xml代码 

1.  <result type="json">  

2.      <param name="enumAsBean">true</param>  

3.  </result>  

 

 

分享到:
评论
1 楼 tomfish88 2012-06-08  
action里面如果有多个方法,如save(),delete(),不同方法return 的json格式是不同的,那怎么设置呢?  如save() 操作完了返回的json是保存结果详细信息,delete()是另外一种格式

请问这种情况改怎么处理呢?

相关推荐

Global site tag (gtag.js) - Google Analytics