是的,这可以使用自定义 ContractResolver 来完成。
你没有展示任何代码,所以我只是举个例子。假设我有一个类Foo,如下所示。我想要序列化输出中的Id 和Name 属性,但我绝对对AlternateName 和Color 不感兴趣。我用[JsonIgnore] 标记了那些。我希望出现描述,但有时这会变得很长,所以我使用了自定义 JsonConverter 来限制它的长度。我还想为描述使用较短的属性名称,所以我用[JsonProperty("Desc")] 标记了它。
class Foo
{
public int Id { get; set; }
public string Name { get; set; }
[JsonIgnore]
public string AlternateName { get; set; }
[JsonProperty("Desc")]
[JsonConverter(typeof(StringTruncatingConverter))]
public string Description { get; set; }
[JsonIgnore]
public string Color { get; set; }
}
当我序列化上述实例时...
Foo foo = new Foo
{
Id = 1,
Name = "Thing 1",
AlternateName = "The First Thing",
Description = "This is some lengthy text describing Thing 1 which you'll no doubt find very interesting and useful.",
Color = "Yellow"
};
string json = JsonConvert.SerializeObject(foo, Formatting.Indented);
...我得到这个输出:
{
"Id": 1,
"Name": "Thing 1",
"Desc": "This is some lengthy text describing Thing 1 "
}
现在,假设我有时想获得完整的 JSON 输出,而忽略了我的自定义。我可以使用自定义ContractResolver 以编程方式“取消应用”类中的属性。这是解析器的代码:
class IgnoreJsonAttributesResolver : DefaultContractResolver
{
protected override IList<JsonProperty> CreateProperties(Type type, MemberSerialization memberSerialization)
{
IList<JsonProperty> props = base.CreateProperties(type, memberSerialization);
foreach (var prop in props)
{
prop.Ignored = false; // Ignore [JsonIgnore]
prop.Converter = null; // Ignore [JsonConverter]
prop.PropertyName = prop.UnderlyingName; // restore original property name
}
return props;
}
}
要使用解析器,我将其添加到 JsonSerializerSettings 并将设置传递给序列化器,如下所示:
JsonSerializerSettings settings = new JsonSerializerSettings();
settings.ContractResolver = new IgnoreJsonAttributesResolver();
settings.Formatting = Formatting.Indented;
string json = JsonConvert.SerializeObject(foo, settings);
输出现在包括被忽略的属性,并且描述不再被截断:
{
"Id": 1,
"Name": "Thing 1",
"AlternateName": "The First Thing",
"Description": "This is some lengthy text describing Thing 1 which you'll no doubt find very interesting and useful.",
"Color": "Yellow"
}
完整演示:https://dotnetfiddle.net/WZpeWt