.Net Core 读取文件时中文乱码问题的解决方法
背景
今天在使用core web api上傳txt文檔的時候本來很順利的,但是一測試發現讀取的中文內容是亂碼的,很是納悶。
出于經驗,立馬把代碼的Encoding.Default改成 Encoding.uft8, 發現還是不行。后面索性把上傳的文件另存為下,特地選擇帶有bom的utf8選項。
但是發現還是亂碼。郁悶。
問題
于是在本能的百度下,發現方法一大堆,但是沒有一個可以解決問題的。
無意中,發現了鏈接,找到了官網?? 如下?
https://docs.microsoft.com/zh-cn/dotnet/api/system.text.encoding.default?view=netcore-3.1#System_Text_Encoding_Default
進去之后,豁然開朗。里面是這么寫的,關于Encoding.Default 屬性的定義是這樣的。
.NET Framework 中的默認屬性
在 Windows 桌面上的 .NET Framework 中, Default 屬性始終獲取系統的活動代碼頁并創建 Encoding 與其對應的對象。?活動代碼頁可能是 ANSI 代碼頁,其中包括 ASCII 字符集以及不同于代碼頁的其他字符。?由于所有 Default 基于 ANSI 代碼頁的編碼都將丟失數據,因此請考慮 Encoding.UTF8 改用編碼。?在 U + 00 到 U + 7F 范圍內,UTF-8 通常是相同的,但可以在不丟失的情況下在 ASCII 范圍外對字符進行編碼。
.NET Core 上的默認屬性
在 .NET Core 中,?Default?屬性始終返回?UTF8Encoding?。?在運行 .NET Core 應用程序的所有操作系統(Windows、Linux 和 macOS)上都支持 UTF-8。
解決辦法
So,.NET Framework 中默認編碼是GB2312,而在 .NET Core 中不支持,若想使用必須得先注冊編碼
代碼如下
var completeFilePath = Path.Combine(filePath, saveName);var stream = formFile.OpenReadStream();Encoding.RegisterProvider(CodePagesEncodingProvider.Instance);Encoding encoding = Encoding.GetEncoding("gb2312");using var reader = new StreamReader(stream, encoding);var input = reader.ReadToEnd();到此,問題解決。
總結
以上是生活随笔為你收集整理的.Net Core 读取文件时中文乱码问题的解决方法的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 我做了一个 Istio Workshop
- 下一篇: BCVP开发者社区2022专属周边第一弹