Json.NET文档说,您使用JsonIgnore
不序列化类中的某些属性:
public class Account
{
public string FullName { get; set; }
public string EmailAddress { get; set; }
[JsonIgnore]
public string PasswordHash { get; set; }
}
在用JsonConvert.SerializeObject
序列化第三方对象时,如何使Json.NET忽略特定属性?
制作一个自定义合同解析程序:
public class ShouldSerializeContractResolver : DefaultContractResolver
{
public static ShouldSerializeContractResolver Instance { get; } = new ShouldSerializeContractResolver();
protected override JsonProperty CreateProperty(MemberInfo member, MemberSerialization memberSerialization)
{
JsonProperty property = base.CreateProperty(member, memberSerialization);
if (typeof(Account).IsAssignableFrom(member.DeclaringType) && member.Name == nameof(Account.PasswordHash))
{
property.Ignored = true;
}
return property;
}
}
我如何测试它:
var account = new Account
{
PasswordHash = "XXAABB"
};
var settings = new JsonSerializerSettings
{
ContractResolver = ShouldSerializeContractResolver.Instance
};
var json = JsonConvert.SerializeObject(account, settings);
Console.WriteLine(json);
幸运的是,Newtonsoft.Json对JsonConvert.SerializeObject()方法有一个重写,它允许我们提供一个类型,这样生成的Json就不会包含该类型中不存在的属性。因此,为了消除属性,您可以创建一个删除了所有敏感属性的Account类的安全副本,并给它一个不同的名称:
public class AccountJSON
{
public string FullName { get; set; }
public string EmailAddress { get; set; }
}
序列化时提供其类型:
var TheAccount = DBContext.Accounts.Find(1);
var TheJSON = Newtonsoft.Json.JsonConvert.SerializeObject(TheAccount, typeof(AccountJSON));
注意:当序列化程序遍历对象时,这可能只适用于一级深度。如果Account对象具有引用更多Account对象的延迟加载属性,则它们可能不会使用您最初提供的"安全"类型。