您的位置:首页 > 编程语言 > Java开发

struts2使用json时需要注意的问题

2010-06-10 10:08 239 查看
JSON(JavaScriptObjectNotation),是一种语言无关的数据交换格式。JSON插件是Structs2的Ajax插件,通过利用JSON插件,开发者可以很方便,灵活的利用Ajax进行开发。Json是一种轻量级的数据交换格式,JSon插件提供了一种名为json的ActionResultType。一旦为Action指定了该结果处理类型,JSON插件就会自动将Action里的数据序列化成JSON格式的数据,并返回给客户端物理视图的JavaScript。简单的说,JSON插件允许我们在JavaScript中异步的调用Action,而且Action不需要指定视图来显示Action的信息显示。而是由JSON插件来负责具体将Action里面具体的信息返回给调用页面。
Json的数据格式可简单如下形式:person={name:'Jim',age:18,gender:'man'}。
如果action的属性很多,我们想要从Action返回到调用页面的数据。这个时候配置includeProperties或者excludeProperties拦截器即可。而这2个拦截器的定义都在struts2的json-default包内,所以要使用该拦截器的包都要继承自json-default。

Xml代码



<struts>

<constantname="struts.objectFactory"value="spring"/>

<includefile="struts-admin.xml"></include>

<packagename="default"extends="json-default">

<actionname="person"class="com.person.PersonAction"method="view">

<resulttype="json">

<paramname="includeProperties">

person/.name,persoon/.age,person/.gender

</param>>

</result>

</action>

</package>

</struts>

利用Struts2的支持的可配置结果,可以达到过滤器的效果。Action的处理结果配置支持正则表达式。
但是如果返回的对象是一个数组格式的Json数据。比如pesonBean中有对象persion1...person9,而我只要person1的json数据,则可以用如下的正则表达式。

Xml代码



<struts>

<constantname="struts.objectFactory"value="spring"/>

<includefile="struts-admin.xml"></include>

<packagename="default"extends="json-default">

<actionname="person"class="com.person.PersonAction"method="view">

<resulttype="json">

<paramname="includeProperties">

person/[/d+/]/.person1

</param>>

</result>

</action>

</package>

</struts>


excludeProperties拦截器的用法与此类同,如果拦截的仅仅是一个对象,如果拦截掉personBean的整个对象。

Xml代码



<struts>

<constantname="struts.objectFactory"value="spring"/>

<includefile="struts-admin.xml"></include>

<packagename="default"extends="json-default">

<actionname="person"class="com.person.PersonAction"method="view">

<resulttype="json">

<paramname="excludeProperties">

person

</param>>

</result>

</action>

</package>

</struts>

需要注意的是,如果用JSON插件把返回结果定为JSON。而JSON的原理是在ACTION中的get方法都会序列化,
所以前面是get的方法只要没指定不序列化,都会执行。
如果该方法一定要命名为get*(比如实现了什么接口),
那么可以在该方法的前面加注解声明该方法不做序列化。
注解的方式为:@JSON(serialize=false)

除此之外,JSON注释还支持如下几个域:
  serialize:设置是否序列化该属性
  deserialize:设置是否反序列化该属性。
  format:设置用于格式化输出、解析日期表单域的格式。例如"yyyy-MM-dd'T'HH:mm:ss"。

//使用注释语法来改变该属性序列化后的属性名
 @JSON(name="newName")
 publicStringgetName()
 {
  returnthis.name;
 }
需要引入importcom.googlecode.jsonplugin.annotations.JSON;

@JSON(serialize=false)
publicUsergetUser(){
returnthis.User;
}

@JSON(format="yyyy-MM-dd")
publicDategetStartDate(){
returnthis.startDate;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: