Web乱码解决方法

简介:

最近被乱码折腾的够呛,现在工作告一段落,出来总结一下Web中传递数据乱码的情况,希望同样被乱码困扰的朋友能够安心入睡!

Web数据提交有两种方法:GET 和 POST。关于这两种方法的介绍,请看这里:Http之Get/Post请求区别。我在这里要介绍的是如何在程序中获取HTTPRequest数据,并成功解决编码不同时所引起乱码的问题。

现在我们开始,先看一段HTML代码:

 
   
复制代码
<! DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd" >
< html xmlns ="http://www.w3.org/1999/xhtml" >
< head >
< meta http-equiv ="Content-Type" content ="text/html; charset=gb2312" />
< title >无标题文档 </ title >
</ head >

< body >
< form id ="myForm" action ="http://localhost:9000/WebForm1.aspx" method ="post" >
名称: < input tyep ="text" name ="name" width ="200px" value ="独钓寒江" />
< br />
年龄: < input tyep ="text" name ="age" width ="200px" value ="24" />
< br />
< br />
< input type ="submit" value ="提交" />
</ form >
</ body >
</ html >
复制代码

在这个HTML文件中,我们使用的编码是GB2312,Form表单中包含name和age两个数据。首先将method设置为GET方法:

< form id ="myForm" action ="http://localhost:9000/WebForm1.aspx" method ="GET" >

另外我们再新建一个Web应用程序,并在本地新建一个站点,将端口设置为9000,添加一个页面,名称为WebForm1.aspx,也就是上面Form表单中的action所指向的地址http://localhost:9000/WebForm1.aspx

在点击“提交”按钮的时候,我们可以在WebForm1中获取到网页的参数,具体有如下几种方式:

Request[ " name "]
Request.Params[ " name "]
Request.QueryString[ " name "]

这三种方法得到的字符串都是经过默认编码转换的,因为我们使用vs建立项目时编码默认为UTF-8,所以这时便会出现乱码。这是第一种问题,稍候我们将解决这个问题。

接下来将method设置为POST方法:

< form id ="myForm" action ="http://localhost:9000/WebForm1.aspx" method ="POST" >

在点击“提交”按钮的时候,我们可以在WebForm1中获取到网页的参数,具体有如下几种方式:

Request[ " name "]
Request.Params[ " name "]
Request.Form[ " name "]

和第一种问题相同,经过默认的UTF-8转换,这里还会出现乱码。这是第二种问题。


问题一的解决方法:

复制代码
StringBuilder sb = new StringBuilder();
IServiceProvider provider = (IServiceProvider)HttpContext.Current;
HttpWorkerRequest worker = (HttpWorkerRequest)provider.GetService( typeof(HttpWorkerRequest));
byte[] bs = worker.GetQueryStringRawBytes();
String queryString = Encoding.GetEncoding( " GB2312 ").GetString(bs);
NameValueCollection querys = HttpUtility.ParseQueryString(queryString, Encoding.GetEncoding( " GB2312 "));

foreach (var item in querys.Keys)
{
sb.AppendFormat( " {0}:{1}<br /> ", item.ToString(), querys[item.ToString()]);
}
复制代码

问题二的解决方法:

复制代码
// 获取到InputStream
System.IO.Stream str = Request.InputStream;
Int32 strLen, strRead;
strLen = Convert.ToInt32(str.Length);
byte[] strArr = new byte[strLen];
strRead = str.Read(strArr, 0, strLen);

string queryString = HttpUtility.UrlDecode(strArr, System.Text.Encoding.GetEncoding( " GB2312 "));

NameValueCollection querys = HttpUtility.ParseQueryString(queryString, Encoding.GetEncoding( " GB2312 "));

foreach (var item in querys.Keys)
{
sb.AppendFormat( " {0}:{1}<br /> ", item.ToString(), querys[item.ToString()]);
}
复制代码

另外,对于第一种方法,还可以直接将URL用GB2312解码,这里不再贴出代码。

有了这两种方法,不管是怎样的乱码,都可以高枕无忧了。




本文转自齐师傅博客园博客,原文链接:http://www.cnblogs.com/youring2/archive/2011/03/24/1993717.html,如需转载请自行联系原作者 

相关文章
|
6月前
|
JSON 缓存 Go
Golang 语言 Web 框架 beego v2 之控制器方法和输入输出数据
Golang 语言 Web 框架 beego v2 之控制器方法和输入输出数据
51 0
|
7月前
|
安全 中间件 Apache
【Web安全】不安全的HTTP方法
围绕渗透攻防层面来看不安全的HTTP方法漏洞的检测发现修复等手法。
263 1
|
8月前
vite环境引入web worker方法
在 vite 环境中使用 web worker 时,如果遇到生产环境中 worker.js 文件的 MIME 类型被识别为 text/html,导致报错无法运行的情况时,可以参考以下两种方法,原理都是避免编译时产出单独的 worker.js 文件。方法一worker文件不需要包装,引入时后缀增加 ?worker&inline,使用时直接 new ImportedWorker();self.
425 0
|
1月前
|
安全 测试技术 API
请描述在 Python WEB 开发中常用的测试方法。
请描述在 Python WEB 开发中常用的测试方法。
18 0
|
3月前
|
Web App开发 前端开发 JavaScript
Web前端性能测试方法
Web前端性能测试方法
|
3月前
|
移动开发 前端开发 JavaScript
web前端之ES6的实用深度解构赋值方法、复杂的解构赋值
web前端之ES6的实用深度解构赋值方法、复杂的解构赋值
29 1
|
3月前
|
搜索推荐 应用服务中间件 Apache
HTTP状态码301(永久重定向)不同Web服务器的配置方法
当用户或搜索引擎向服务器发出浏览请求时,服务器返回的HTTP数据流中头信息(header)中包含状态码301,以向用户表示该资源已经永久改变了位置。
85 2
|
4月前
|
应用服务中间件 数据安全/隐私保护
Tomcat【部署 02】Web端403 Access Denied You are not authorized to view this page解决方法(Tomcat 10.2.12 版本)
Tomcat【部署 02】Web端403 Access Denied You are not authorized to view this page解决方法(Tomcat 10.2.12 版本)
125 0
|
5月前
|
存储 移动开发 搜索推荐
Web开发中会话跟踪的方法有哪些?
Web开发中会话跟踪的方法有哪些?
31 0
|
5月前
|
Web App开发 Linux UED
Web 网站 LCP 性能指标的度量方法
Web 网站 LCP 性能指标的度量方法
52 1