JSON.NET使用Type参数反序列化为对象

ava*_*gen 22 c# types casting json.net deserialization

我有以下问题,我无法解决:

我有不同的类,它们都实现了一个名为的接口IProtocol.的命名,现在,SimpleProtocol,ParallelProtocol.我想坚持这些对象,所以我使用JSON.NET,一切正常.除非我试图反序列化它们,当我知道它们应该是什么类型时,它会完美地工作,例如:

SimpleProtocol p = JsonConvert.DeserializeObject<SimpleProtocol>(myJsonData);
Run Code Online (Sandbox Code Playgroud)

但是,我现在处于需要加载JSON数据并IProtocol返回的情况,但可以理解的是,JSON不允许这样做; 例如,这样的事情并没有工作:

IProtocol p1 = JsonConvert.DeserializeObject<IProtocol>(myJsonData); // does not work
IProtocol p2 = (IProtocol)JsonConvert.DeserializeObject(myJsonData); // also, does not work
Run Code Online (Sandbox Code Playgroud)

所以,查找API我发现了这个方法签名:

public static Object DeserializeObject(
    string value,
    Type type
)
Run Code Online (Sandbox Code Playgroud)

看起来就像我需要的东西,所以通过将字符串中的类型持久化并检索它来尝试:

// test
Type protocolType = Type.GetType("MyApp.Protocols.SimpleProtocol");
IProtocol p1 = JsonConvert.DeserializeObject(myJsonData, protocolType);
Run Code Online (Sandbox Code Playgroud)

我得到一个错误,这是不可能投下Newtonsoft.Json.Linq.JObjectIProtocol.这很奇怪,我不知道如何解决这个问题.

在泛型方法中传递Type对象是不可能的,所以我基本上被困在这里.有没有办法解决这个问题,最好不要使用反射?在我看来,这是一个完全正常的用例.

我能做什么,但对我来说似乎有点"脏",是创建一个简单的包装类,它包含一个IProtocol实例并序列化/反序列化?

ava*_*gen 32

看来我使用这种方法的初步方法毕竟是正确的:

public static Object DeserializeObject(
    string value,
    Type type
)
Run Code Online (Sandbox Code Playgroud)

问题是我将我的对象类型持久化为使用MyProtocol.GetType().FullName,从而产生了一个值

Type protocolType = Type.GetType(PersistedTypeString);

成为具有null值的类型.但是通过使用MyProtocol.GetType().AssemblyQualifiedName一切工作正常(ps这也包含在Type.GetType()的文档中)

这是我的代码示例:

Type ProtocolType = Type.GetType(MetaData["ProtocolType"]);
var Protocol = JsonConvert.DeserializeObject(Data["Protocol"], 
                                             ProtocolType, 
                                             JsonProtocolPersister.DefaultSettings);
return (IProtocol)Protocol;
Run Code Online (Sandbox Code Playgroud)