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