摘要
在序列化对象,总会遇到一些敏感的信息,这些信息,并不想对调用接口的用户暴露出来,又或者移动端调用接口的时候,为了不返回没用的信息占用流量,这个时候也需要把一些信息给过滤掉。
系列文章
一个例子
namespace Json.NetDemo
{
class User
{ public string Name { set; get; } public string Pwd { set; get; } public DateTime Birthday { set; get; }
}
class Program
{
static void Main(string[] args)
{
Console.WriteLine(JsonConvert.SerializeObject(new User { Name = "wolfy", Pwd = "", Birthday = DateTime.Now }));
Console.Read();
}
}
}
User类是一个再普通不过的一个类了。这个时候有其他的client需要调用接口查找该用户的信息。这个时候如果直接把序列化的结果返回,这个时候就会把pwd字段暴露给调用方。
Json.net有一些特性个作用在字段或者属性上面
JsonIgnoreAttribute
序列化的时候忽略字段或者属性
JsonPropertyAttribute
可以通过这个特性对字段进行重命名。
JsonConverterAttribute
指定序列化器。用于指派转换对象的JsonSerializer。这个特性可以修饰类或类成员。用于修饰类时,通过此特性指派的JsonConverter会被设置为序列化类的默认方式。用于修饰属性或域成员时,被指派的JsonConverter会序列化它们的值。
class User
{
[JsonProperty("UserName")]
public string Name { set; get; }
[JsonIgnore]
public string Pwd { set; get; }
[JsonConverter(typeof(IsoDateTimeConverter))]
public DateTime Birthday { set; get; }
}
通过上面的特性改造user类