文章詳情頁
Asp.Net 自定義轉(zhuǎn)換器JsonConverter的使用詳解
瀏覽:117日期:2022-06-12 13:59:10
例如api返回了以下json串 (infcode的值有可能時string 也可能時number
有時候返回時這個
{
"infcode": -1,
"detail_msg": null
}
有時后也可能時這個
{
"infcode": "-1",
"detail_msg": null
}
本人之前在springboot開發(fā)的時候,使用的是fastjson,所以,只要在實(shí)體類定義屬性為String,那么無論是number還是字符串,都會轉(zhuǎn)換成String.
但是,到了.netcore這邊的就不太管用了. 如果實(shí)體類定義是string, json字段是number的話.會拋出異常The JSON value could not be converted to System.String
默認(rèn)的反序列的寫法 (以下),會報錯,不能直接將number轉(zhuǎn)成string
實(shí)體類變量= JsonSerializer.Deserialize<實(shí)體類類型>(jsonString);
要想實(shí)現(xiàn)無論是number還是字符串, 都能夠反序列化成功的話.這里就需要用到JsonConverter來實(shí)現(xiàn)了.這里介紹兩種比較直觀的寫法
通過JsonSerializerOptions參數(shù),綁定JsonConverter來實(shí)現(xiàn)
在實(shí)體類的屬性上 增加JsonConverter注解來實(shí)現(xiàn) (不確定在C#是不是叫注解,在java中是叫注解)
通過JsonSerializerOptions參數(shù),綁定JsonConverter來實(shí)現(xiàn)
這里新建一個類,例如取名為IntJsonConverter.cs .讓其繼承JsonConverter.
然后重寫Read方法.
下面是關(guān)鍵部分代碼
public class IntJsonConverter : JsonConverter<string> //這里因?yàn)閷?shí)體類的屬性是string 這里就配置儲層string
{
public override string? Read(ref Utf8JsonReader reader, Type typeToConvert, JsonSerializerOptions options)
{
if (reader.TokenType == JsonTokenType.Number)
{
//這里就簡單處理以下 如果時number, 轉(zhuǎn)換為decimal后在toString即可
return reader.GetDecimal().ToString();
}
else
{
return reader.GetString();
}
}
}
然后再需要轉(zhuǎn)換的地方 配置以下反序列化的選項JsonSerializerOptions
var serializeOptions = new JsonSerializerOptions
{
WriteIndented = true,
};
serializeOptions.Converters.Add(new IntJsonConverter());
fsiResponse = JsonSerializer.Deserialize<FsiResponse>(contentStream, serializeOptions);
這樣就可以了
在實(shí)體類的屬性上 增加JsonConverter注解來實(shí)現(xiàn)
同樣需要自定義一個JsonConverter類 ,同剛才的步驟.
在實(shí)體類上,增加注解,只向這個轉(zhuǎn)換器
public class FsiResponse
{
[JsonConverter(typeof(IntJsonConverter))]
public string? infcode { get; set; }
然后反序列化的時候, 按照默認(rèn)的寫法即可
fsiResponse = JsonSerializer.Deserialize<FsiResponse>(contentStream);
有時候返回時這個
{
"infcode": -1,
"detail_msg": null
}
有時后也可能時這個
{
"infcode": "-1",
"detail_msg": null
}
本人之前在springboot開發(fā)的時候,使用的是fastjson,所以,只要在實(shí)體類定義屬性為String,那么無論是number還是字符串,都會轉(zhuǎn)換成String.
但是,到了.netcore這邊的就不太管用了. 如果實(shí)體類定義是string, json字段是number的話.會拋出異常The JSON value could not be converted to System.String
默認(rèn)的反序列的寫法 (以下),會報錯,不能直接將number轉(zhuǎn)成string
實(shí)體類變量= JsonSerializer.Deserialize<實(shí)體類類型>(jsonString);
要想實(shí)現(xiàn)無論是number還是字符串, 都能夠反序列化成功的話.這里就需要用到JsonConverter來實(shí)現(xiàn)了.這里介紹兩種比較直觀的寫法
通過JsonSerializerOptions參數(shù),綁定JsonConverter來實(shí)現(xiàn)
在實(shí)體類的屬性上 增加JsonConverter注解來實(shí)現(xiàn) (不確定在C#是不是叫注解,在java中是叫注解)
通過JsonSerializerOptions參數(shù),綁定JsonConverter來實(shí)現(xiàn)
這里新建一個類,例如取名為IntJsonConverter.cs .讓其繼承JsonConverter.
然后重寫Read方法.
下面是關(guān)鍵部分代碼
public class IntJsonConverter : JsonConverter<string> //這里因?yàn)閷?shí)體類的屬性是string 這里就配置儲層string
{
public override string? Read(ref Utf8JsonReader reader, Type typeToConvert, JsonSerializerOptions options)
{
if (reader.TokenType == JsonTokenType.Number)
{
//這里就簡單處理以下 如果時number, 轉(zhuǎn)換為decimal后在toString即可
return reader.GetDecimal().ToString();
}
else
{
return reader.GetString();
}
}
}
然后再需要轉(zhuǎn)換的地方 配置以下反序列化的選項JsonSerializerOptions
var serializeOptions = new JsonSerializerOptions
{
WriteIndented = true,
};
serializeOptions.Converters.Add(new IntJsonConverter());
fsiResponse = JsonSerializer.Deserialize<FsiResponse>(contentStream, serializeOptions);
這樣就可以了
在實(shí)體類的屬性上 增加JsonConverter注解來實(shí)現(xiàn)
同樣需要自定義一個JsonConverter類 ,同剛才的步驟.
在實(shí)體類上,增加注解,只向這個轉(zhuǎn)換器
public class FsiResponse
{
[JsonConverter(typeof(IntJsonConverter))]
public string? infcode { get; set; }
然后反序列化的時候, 按照默認(rèn)的寫法即可
fsiResponse = JsonSerializer.Deserialize<FsiResponse>(contentStream);
標(biāo)簽:
ASP.NET
相關(guān)文章:
1. ASP.NET MVC通過勾選checkbox更改select的內(nèi)容2. ASP.NET堆和棧二之值類型和引用類型的參數(shù)傳遞和內(nèi)存分配3. asp.net core項目授權(quán)流程詳解4. ASP.Net Core對USB攝像頭進(jìn)行截圖5. ASP.NET MVC使用JSAjaxFileUploader插件實(shí)現(xiàn)單文件上傳6. ASP.NET MVC視圖頁使用jQuery傳遞異步數(shù)據(jù)的幾種方式詳解7. ASP.NET Core自定義中間件的方式詳解8. ASP.NET堆和棧四之對托管和非托管資源的垃圾回收和內(nèi)存分配9. ASP.NET泛型二之泛型的使用方法10. ASP.NET泛型三之使用協(xié)變和逆變實(shí)現(xiàn)類型轉(zhuǎn)換
排行榜
