巧用escape解决ASP.NET中URL传参乱码问题

1 < href ="#"  onclick ="window.open('http://www.mzwu.com/test.aspx?title=木子屋');" > Links </ a >

在test.aspx中,只要获取title参数的值并显示出来即可,本来用Request["title"]就可解决的问题却因链接所处页面的编码不同而变得复杂起来:

当链接所处的页面是用GB2312编码时,如果test.aspx也是GB2312则获取的参数值不乱码,否则乱码;
当链接所处的页面是用UTF-8编码时,如果test.aspx也是UTF-8则获取的参数值不乱码,否则乱码;

gb.htm:
 1 < html >
 2 < head >
 3 < meta  http-equiv ="Content-Type"  content ="text/html; charset=gb2312"   />
 4 < title > gb2312测试页 </ title >
 5 </ head >
 6
 7 < body >
 8 < href ="#"  onclick ="window.open('http://www.mzwu.com/test.aspx?title=木子屋');" > Links </ a >
 9 </ body >
10 </ html >

utf8.htm:
 1 < html >
 2 < head >
 3 < meta  http-equiv ="Content-Type"  content ="text/html; charset=utf-8"   />
 4 < title > utf-8测试页 </ title >
 5 </ head >
 6
 7 < body >
 8 < href ="#"  onclick ="window.open('http://www.mzwu.com/test.aspx?title=木子屋');" > Links </ a >
 9 </ body >
10 </ html >

test.aspx.cs:
1 private   void  Page_Load( object  sender, System.EventArgs e)
2 {
3    String Request1;
4    Request1 = Request["title"];
5    Response.Write(Request1);
6}

有没办法让test.aspx不论URL中的参数以何种方式编码都能正常的获取显示呢?通过配置web.config的<globalization requestEncoding="gb2312|utf-8" />都只会顾此失彼,不能完美的解决我们的问题。最终,在老农的提示下使用JS的escape问题得以完美解决:
gb.htm:
 1 < html >
 2 < head >
 3 < meta  http-equiv ="Content-Type"  content ="text/html; charset=gb2312"   />
 4 < title > gb2312测试页 </ title >
 5 < script  language ="javascript" >
 6function winopen(url,width,height)
 7{
 8    var newurl,arrurl;
 9    if(typeof(url) == "#ff0000" || url == "")
10    {
11        return ;
12    }

13    else
14    {
15        if(url.indexOf("?"== -1)
16        {
17            newurl = url;
18        }

19        else
20        {
21            newurl = url.substring(0,url.indexOf("?")+1);
22            arrurl = url.substring(url.indexOf("?")+1).split("&");
23            for(var i =0;i<arrurl.length;i++)
24            {
25                newurl += arrurl[i].split("=")[0+ "=" + escape(arrurl[i].split("=")[1]) + "&";
26            }

27            newurl = newurl.substring(0,newurl.length-1);
28        }

29    }

30    if(typeof(width) != "number" || typeof(height) != "number")
31    {
32        window.open(newurl);
33    }

34    else
35    {
36        window.open(newurl,"","width=" + width + ",height=" + height);
37    }

38}

39
</ script >
40 </ head >
41
42 < body >
43 < href ="#"  onclick ="winopen('http://www.mzwu.com/test.aspx?title=木子屋');" > Links </ a >
44 </ body >
45 </ html >

utf8.htm:
 1 < html >
 2 < head >
 3 < meta  http-equiv ="Content-Type"  content ="text/html; charset=utf-8"   />
 4 < title > utf-8测试页 </ title >
 5 < script  language ="javascript" >
 6function winopen(url,width,height)
 7{
 8    var newurl,arrurl;
 9    if(typeof(url) == "undefined" || url == "")
10    {
11        return ;
12    }

13    else
14    {
15        if(url.indexOf("?"== -1)
16        {
17            newurl = url;
18        }

19        else
20        {
21            newurl = url.substring(0,url.indexOf("?")+1);
22            arrurl = url.substring(url.indexOf("?")+1).split("&");
23            for(var i =0;i<arrurl.length;i++)
24            {
25                newurl += arrurl[i].split("=")[0+ "=" + escape(arrurl[i].split("=")[1]) + "&";
26            }

27            newurl = newurl.substring(0,newurl.length-1);
28        }

29    }

30    if(typeof(width) != "number" || typeof(height) != "number")
31    {
32        window.open(newurl);
33    }

34    else
35    {
36        window.open(newurl,"","width=" + width + ",height=" + height);
37    }

38}

39
</ script >
40 </ head >
41
42 < body >
43 < href ="#"  onclick ="winopen('http://www.mzwu.com/test.aspx?title=木子屋',300,400);" > Links </ a >
44 </ body >
45 </ html >

现在完全不用考虑链接所在页面的编码方式,也不用绞尽脑汁去想如何在test.aspx对不同编码的参数值进行转换,只需用一个escape就够了,very good!

转载于:https://www.cnblogs.com/dnawo/archive/2007/12/27/1016241.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值