码迷,mamicode.com
首页 > Web开发 > 详细

使用HttpWebRequest和HttpWebResponse时接收数据中文乱码的情况

时间:2018-11-27 17:13:15      阅读:167      评论:0      收藏:0      [点我收藏+]

标签:情况   读取   数据   system   .net   utf-8   处理   操作   方法   

今天在调试一个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时接收数据中文乱码的情况

标签:情况   读取   数据   system   .net   utf-8   处理   操作   方法   

原文地址:https://www.cnblogs.com/zhao-y/p/10026521.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!