栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

如何调用JsonConvert.DeserializeObject并禁用通过[JsonConverter]应用于基本类型的JsonConverter?

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

如何调用JsonConvert.DeserializeObject并禁用通过[JsonConverter]应用于基本类型的JsonConverter?

既然你已经添加

[JsonConverter(typeof(JsonProductConverted))]
直接到你的
Product
类型,你可以一个虚拟的转换器添加到
ProductImpl
该收益
false
来自
CanRead
CanWrite

[JsonConverter(typeof(NoConverter))]public class ProductImpl : Product{}public class NoConverter : JsonConverter{    public override bool CanConvert(Type objectType)    {        return false;    }    public override bool CanRead { get { return false; } }    public override object ReadJson(JsonReader reader, Type objectType, object existingValue, JsonSerializer serializer)    {        throw new NotImplementedException();    }    public override bool CanWrite { get { return false; } }    public override void WriteJson(JsonWriter writer, object value, JsonSerializer serializer)    {        throw new NotImplementedException();    }}

这将覆盖基类的转换器,然后回退到用于读取和写入的默认序列化

样本.Net小提琴。

另一种选择是使用

serializer.Populate()
。这样可以避免调用对象本身的转换器:

public class JsonProductConverted : JsonTypeInferringConverterbase{    protected override Type InferType(Type objectType, JObject json)    {        //var type = GetTypeFromId((int) json["typeId"]); // Construct type from field in         return typeof(ProductImpl);    }    public override bool CanConvert(Type objectType)    {        return false;    }}public abstract class JsonTypeInferringConverterbase : JsonConverter{    public override bool CanWrite { get { return false; } }    public override void WriteJson(JsonWriter writer, object value, JsonSerializer serializer)    {        throw new NotImplementedException();    }    protected abstract Type InferType(Type objectType, JObject json);    protected virtual object CreateObject(Type actualType, JsonSerializer serializer, JObject json)    {        var contract = (JsonObjectContract)serializer.ContractResolver.ResolveContract(actualType);        return contract.DefaultCreator();    }    public override object ReadJson(JsonReader reader, Type objectType, object existingValue, JsonSerializer serializer)    {        if (reader.TokenType == JsonToken.Null) return null;        var json = JObject.Load(reader);        var actualType = InferType(objectType, json);        // Construct object (or reuse existingValue if compatible)        if (existingValue == null || !actualType.IsAssignableFrom(existingValue.GetType()))        { existingValue = CreateObject(actualType, serializer, json);        }        // Populate object.        using (var subReader = json.CreateReader())        { serializer.Populate(subReader, existingValue);        }        return existingValue;    }}

请注意,具体对象必须具有无参数的构造函数才能起作用。如果没有,您可以

protected virtual object CreateObject(TypeactualType, JsonSerializer serializer, JObjectjson)
通过反序列化内的select属性来覆盖并手动调用参数化的构造函数
JObject json

样本小提琴2。



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/569105.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号