详解Struts2中json 相互引用死循环解决办法
程序员文章站
2024-03-08 21:32:40
方法1 :利用struts 2的支持的可配置结果,可以达到过滤器的效果。action的处理结果配置支持正则表达式。
但是如果返回的对象是一个数组格式的json数据。比如p...
方法1 :利用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>
方法2:需要注意的是,如果用json插件把返回结果定为json。而json的原理是在action中的get方法都会序列化
所以前面是get的方法只要没指定不序列化,都会执行。 如果该方法一定要命名为get*(比如实现了什么接口), 那么可以在该方法的前面加注解声明该方法不做序列化。
注解的方式为:@json(serialize=false)
除此之外,json注释还支持如下几个域:
- serialize:设置是否序列化该属性
- deserialize:设置是否反序列化该属性。
- format:设置用于格式化输出、解析日期表单域的格式。例如”yyyy-mm-dd't'hh:mm:ss”。
//使用注释语法来改变该属性序列化后的属性名 @json(name="newname") public string getname() { return this.name; }
需要引入 import org.apache.struts2.json.annotations.json;
@json(serialize=false) public user getuser() { return this.user; } @json(format="yyyy-mm-dd") public date getstartdate() { return this.startdate; }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
上一篇: Java中常见的陷阱题及答案