详解Struts2中json 相互引用死循环解决办法

来源:爱站网时间:2020-04-22编辑:网友分享
因为所有操作包都继承了crudstack,所以默认情况下操作返回类型不能使用JSON的,在这种情况下,需要我们自行更改默认继承包,下面是爱站技术频道小编给大家整理的详解Struts2中json 相互引用死循环解决办法,希望能够对大家有所帮助!

因为所有操作包都继承了crudstack,所以默认情况下操作返回类型不能使用JSON的,在这种情况下,需要我们自行更改默认继承包,下面是爱站技术频道小编给大家整理的详解Struts2中json 相互引用死循环解决办法,希望能够对大家有所帮助!

方法1 :利用Struts 2的支持的可配置结果,可以达到过滤器的效果。Action的处理结果配置支持正则表达式。

但是如果返回的对象是一个数组格式的Json数据。比如peson Bean中有对象persion1…person9,而我只要person1的json数据, 则可以用如下的正则表达式。

     
      person/[/d+/]/.person1
      >     
    

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

     
      person
      >     
    

方法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;
}

以上是爱站技术频道介绍的关于详解Struts2中json 相互引用死循环解决办法,希望能帮助你,我们还整理了最新的专业内容,让你能及时了解最全最新的编程资讯。

上一篇:java中读写Properties属性文件公用方法详解

下一篇:Java快速批量移动文件的实现方法

您可能感兴趣的文章

相关阅读

热门软件源码

最新软件源码下载