From b86ca3cf1cc9712fc2dd187a98b7f2f1692d9be6 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E9=AB=98=E9=93=81?= Date: Sun, 26 Jul 2020 23:11:19 +0800 Subject: [PATCH] bug fixed for AfterFilter, fix #3217 --- .../fastjson/serializer/AfterFilter.java | 3 +- .../json/bvt/issue_3300/Issue3217.java | 98 +++++++++++++++++++ 2 files changed, 100 insertions(+), 1 deletion(-) create mode 100644 src/test/java/com/alibaba/json/bvt/issue_3300/Issue3217.java diff --git a/src/main/java/com/alibaba/fastjson/serializer/AfterFilter.java b/src/main/java/com/alibaba/fastjson/serializer/AfterFilter.java index aa269df11e..81c39ac8f7 100644 --- a/src/main/java/com/alibaba/fastjson/serializer/AfterFilter.java +++ b/src/main/java/com/alibaba/fastjson/serializer/AfterFilter.java @@ -11,10 +11,11 @@ public abstract class AfterFilter implements SerializeFilter { private final static Character COMMA = Character.valueOf(','); final char writeAfter(JSONSerializer serializer, Object object, char seperator) { + JSONSerializer last = serializerLocal.get(); serializerLocal.set(serializer); seperatorLocal.set(seperator); writeAfter(object); - serializerLocal.set(null); + serializerLocal.set(last); return seperatorLocal.get(); } diff --git a/src/test/java/com/alibaba/json/bvt/issue_3300/Issue3217.java b/src/test/java/com/alibaba/json/bvt/issue_3300/Issue3217.java new file mode 100644 index 0000000000..e54e477751 --- /dev/null +++ b/src/test/java/com/alibaba/json/bvt/issue_3300/Issue3217.java @@ -0,0 +1,98 @@ +package com.alibaba.json.bvt.issue_3300; + +import com.alibaba.fastjson.JSON; +import com.alibaba.fastjson.serializer.AfterFilter; +import junit.framework.TestCase; + +import java.util.ArrayList; +import java.util.List; + +public class Issue3217 extends TestCase { + + public void test_for_issue() throws Exception { + RefAfterFilterTest refAfterFilterTest = new RefAfterFilterTest(); + + List items = new ArrayList(2); + Category category = new Category("category"); + items.add(new Item("item1",category)); + items.add(new Item("item2",category)); + + System.out.println(JSON.toJSONString(items,refAfterFilterTest)); + } + + public static class RefAfterFilterTest extends AfterFilter { + + private Category category = new Category("afterFilterCategory"); + + @Override + public void writeAfter(Object object) { + + if (object instanceof Item) { + + this.writeKeyValue("afterFilterCategory", category); + /*多加一个属性报错,原因是category是object也触发了writeAfter,当前线程变量serializer被设置为null了serializerLocal.set(null); + *这两个write换个顺序就不会报错 + */ + this.writeKeyValue("afterFilterTwo", "two"); + + } + } + } + + public static class Category { + + private String name; + + public Category(String name){ + this.name = name; + } + + public String getName() { + return name; + } + + public void setName(String name) { + this.name = name; + } + } + + public static class Item { + + private String name; + + private Category category; + + private String barcode; + + + public Item(String name,Category category){ + this.name = name; + this.category = category; + } + + public String getName() { + return name; + } + + public void setName(String name) { + this.name = name; + } + + public Category getCategory() { + return category; + } + + public void setCategory(Category category) { + this.category = category; + } + + public String getBarcode() { + return barcode; + } + + public void setBarcode(String barcode) { + this.barcode = barcode; + } + + } +}