使用HttpWebRequest和HttpWebResponse时接收数据中文乱码的情况
Posted i丶星空
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了使用HttpWebRequest和HttpWebResponse时接收数据中文乱码的情况相关的知识,希望对你有一定的参考价值。
今天在调试一个get请求的接口的时候发现HttpWebResponse方法接收数据的时候,中文出现乱码的情况。
原因是格式编码转码的问题。
原来自从Windows 2000之后的操作系统在文件处理时默认编码采用Unicode,所以.Net 的文件默认编码也是Unicode。除非另外指定,StreamReader 的默认编码为 Unicode,而不是当前系统的 ANSI 代码页。但是文档大部分还是以ANSI编码储存,中文文本使用的是gb2312,所以才造成中文乱码的状况,也就是说在读取文本的时候要指定编码格式。
解决方式
StreamReader myStreamReader = new StreamReader(myResponseStream, Encoding.GetEncoding("utf-8"));
将Encoding.GetEncoding("utf-8")更改为默认编码格式。
StreamReader myStreamReader = new StreamReader(myResponseStream, System.Text.Encoding.Default);
就ok;饿
以上是关于使用HttpWebRequest和HttpWebResponse时接收数据中文乱码的情况的主要内容,如果未能解决你的问题,请参考以下文章
Web 请求失败,但仅适用于 localhost 和使用 System.Net.HttpWebRequest