JSON(Java Script Object Notation),是一種語言無關的數據交換格式。
JSON插件是Structs 2 的Ajax插件,經過利用JSON插件,開發者能夠很方便,靈活的利用Ajax進行開發。
Json是一種輕量級的數據交換格式,JSon插件提供了一種名爲json的Action ResultType 。
一旦爲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。
<struts>
<constant name="struts.objectFactory" value="spring"/>
<include file="struts-admin.xml"></include>
<package name="default" extends="json-default">
<action name="person" class="com.person.PersonAction" method="view">
<result type="json">
<param name="includeProperties">
person/.name,persoon/.age,person/.gender
</param>>
</result>
</action>
</package>
</struts>
利用Struts 2的支持的可配置結果,能夠達到過濾器的效果。Action的處理結果配置支持正則表達式。
可是若是返回的對象是一個數組格式的Json數據。好比peson Bean中有對象persion1...person9,而我只要person1的json數據,
則能夠用以下的正則表達式。
<struts>
<constant name="struts.objectFactory" value="spring"/>
<include file="struts-admin.xml"></include>
<package name="default" extends="json-default">
<action name="person" class="com.person.PersonAction" method="view">
<result type="json">
<param name="includeProperties">
person/[/d+/]/.person1
</param>>
</result>
</action>
</package>
</struts>
excludeProperties攔截器的用法與此類同,若是攔截的僅僅是一個對象,若是攔截掉person Bean的整個對象。
<struts>
<constant name="struts.objectFactory" value="spring"/>
<include file="struts-admin.xml"></include>
<package name="default" extends="json-default">
<action name="person" class="com.person.PersonAction" method="view">
<result type="json">
<param name="excludeProperties">
person
</param>>
</result>
</action>
</package>
</struts>正則表達式
須要注意的是,若是用JSON插件把返回結果定爲JSON。而JSON的原理是在ACTION中的get方法都會序列化,
因此前面是get的方法只要沒指定不序列化,都會執行。
若是該方法必定要命名爲get*(好比實現了什麼接口),
那麼能夠在該方法的前面加註解聲明該方法不作序列化。
註解的方式爲:@JSON(serialize=false)spring
除此以外,JSON註釋還支持以下幾個域:
serialize:設置是否序列化該屬性
deserialize:設置是否反序列化該屬性。
format:設置用於格式化輸出、解析日期表單域的格式。例如"yyyy-MM-dd'T'HH:mm:ss"。json
//使用註釋語法來改變該屬性序列化後的屬性名
@JSON(name="newName")
public String getName()
{
return this.name;
}
須要引入 import com.googlecode.jsonplugin.annotations.JSON;數組
@JSON(serialize=false)
public User getUser() {
return this.User;
}異步
@JSON(format="yyyy-MM-dd")
public Date getStartDate() {
return this.startDate;
}jsonp