给定我创建了一个声明标识,随后创建了一个主体。然后我序列化主体。检查 json 字符串,我可以确认"角色"声明以及标识是否存在。
反序列化它会导致对象具有空属性。.Claims
和.Identity
丢失。
var identity = new ClaimsIdentity(new List<Claim>() { new Claim("Role", "Admin") });
var principal = new ClaimsPrincipal(identity);
string serialized = JsonConvert.SerializeObject(principal, new JsonSerializerSettings() { ReferenceLoopHandling = ReferenceLoopHandling.Ignore });
ClaimsPrincipal deserialized = JsonConvert.DeserializeObject<ClaimsPrincipal>(serialized); // The object has all properties empty
问:如何确保对象已正确反序列化?
面对同样的问题,我想 claimsPrinciple 是一个"受保护"的对象,不能那么容易"复制"。查看 Swagger 生成的代码,一种解决方案可能是创建新类。以下来自 swagger-gen 的片段:
[System.CodeDom.Compiler.GeneratedCode("NJsonSchema", "9.13.15.0 (Newtonsoft.Json v11.0.0.0)")]
public partial class ClaimsPrincipal
{
[Newtonsoft.Json.JsonProperty("Claims", Required = Newtonsoft.Json.Required.Default, NullValueHandling = Newtonsoft.Json.NullValueHandling.Ignore)]
public System.Collections.Generic.ICollection<Claim> Claims { get; set; }
[Newtonsoft.Json.JsonProperty("Identities", Required = Newtonsoft.Json.Required.Default, NullValueHandling = Newtonsoft.Json.NullValueHandling.Ignore)]
public System.Collections.Generic.ICollection<ClaimsIdentity> Identities { get; set; }
[Newtonsoft.Json.JsonProperty("Identity", Required = Newtonsoft.Json.Required.Default, NullValueHandling = Newtonsoft.Json.NullValueHandling.Ignore)]
public IIdentity Identity { get; set; }
public string ToJson()
{
return Newtonsoft.Json.JsonConvert.SerializeObject(this);
}
public static ClaimsPrincipal FromJson(string data)
{
return Newtonsoft.Json.JsonConvert.DeserializeObject<ClaimsPrincipal>(data);
}
}