zoukankan      html  css  js  c++  java
  • c#asp.net url 传递中文参数要使用 System.Web.HttpUtility.UrlEncode 而不能使用Server.UrlEncode

    最近网站里的参数包括中文的例如:

    http://www.chinapoesy.com/Tag%b0%ae%c7%e9.html

    已开始使用 Server.UrlEncode来做的,但发现,有一些中文在url重写的是说找不到页面,URL的重写规范正则表达式是没有问题的啊。


    后来GG了发现问题所在 Server.UrlEncode编码是使用系统默认的,而  System.Web.HttpUtility.UrlEncode  却可以指定编码。指定了编码为utf-8然后就好了。

     System.Web.HttpUtility.UrlEncode("爱清",Encoding.UTF8) 这样以来就好了。


    下面是转载的:

    在对URL进行编码时,该用哪一个?这两都使用上有什么区别吗?
    测试:

    string file="文件上(传)篇.doc";
    string Server_UrlEncode=Server.UrlEncode(file);
    string Server_UrlDecode=Server.UrlDecode(Server_UrlEncode);
    string HttpUtility_UrlEncode=System.Web.HttpUtility.UrlEncode(file);
    string HttpUtility_UrlDecode=System.Web.HttpUtility.UrlDecode(HttpUtility_UrlEncode);
    Response.Write(
    "原数据:"+file);
    SFun.WriteLine(
    "Server.UrlEncode:"+Server_UrlEncode);
    SFun.WriteLine(
    "Server.UrlDecode:"+Server_UrlDecode);
    SFun.WriteLine(
    "HttpUtility.UrlEncode:"+HttpUtility_UrlEncode);
    SFun.WriteLine(
    "HttpUtility.UrlDecode:"+HttpUtility_UrlDecode);

    输出:
    原数据:文件上(传)篇.doc
    Server.UrlEncode:%ce%c4%bc%fe%c9%cf%a3%a8%b4%ab%a3%a9%c6%aa.doc
    Server.UrlDecode:文件上(传)篇.doc
    HttpUtility.UrlEncode:%e6%96%87%e4%bb%b6%e4%b8%8a%ef%bc%88%e4%bc%a0%ef%bc%89%e7%af%87.doc
    HttpUtility.UrlDecode:文件上(传)篇.doc

    区别在于:HttpUtility.UrlEncode()默认是以UTF8对URL进行编码,而Server.UrlEncode()则以默认的编码对URL进行编码。

    在用 ASP.Net 开发页面的时候, 我们常常通过 System.Web.HttpUtility.UrlEncode 和 UrlDecode 在页面间通过 URL 传递参数. 成对的使用 Encode 和 Decode 是没有问题的.

    但是, 我们在编写文件下载的页面的时候, 常常用如下方法来指定下载的文件的名称:

    Response.AddHeader("Content-Disposition","attachment; filename="
    + HttpUtility.UrlEncode(fileName, Encoding.UTF8));

    之所以转换成 UTF8 是为了支持中文文件名.

    这 时候问题就来了, 因为 HttpUtility.UrlEncode 在 Encode 的时候, 将空格转换成加号('+'), 在 Decode 的时候将加号转为空格, 但是浏览器是不能理解加号为空格的, 所以如果文件名包含了空格, 在浏览器下载得到的文件, 空格就变成了加号.

    一个解决办法是, 在 HttpUtility 的 UrlEncode 之后, 将 "+" 替换成 "%20"( 如果原来是 "+" 则被转换成 "%2b" ) , 如:

    fileName = HttpUtility.UrlEncode(fileName, Encoding.UTF8); 
    fileName 
    = fileName.Replace("+""%20"); 

    不明白微软为什么要把空格转换成加号而不是"%20". 记得 JDK 的 UrlEncoder 是将空格转换成 "%20"的.
    经检查, 在 .Net 2.0 也是这样.

    上面是从别的地方拷贝的,写得很好,我自己的一个程序中也遇到同样的问题,默认aspx是以utf-8为编码的,在我这个程序中必须用gb2312为默认编码
    (<globalization requestEncoding="gb2312" responseEncoding="gb2312"/>),

    问 题出现了,以前没有问题的HttpUtility.UrlDecode在Page.Request回的值是乱码这就是上面说的 HttpUtility.UrlDecode默认以UTF8对URL进行编码,这种情况下面只需将HttpUtility.UrlDecode改成 Server.UrlEncode即可。

     欢迎来爱你网爱你家园做客

  • 相关阅读:
    PHP程序员应当如何保持与时俱进?
    使用validator-api来验证spring-boot的参数
    运维不仅仅是懂Linux就行,还需要知道这些……
    Let's Encrypt: 为CentOS/RHEL 7下的nginx安装https支持-具体案例
    少年,是时候换种更优雅的方式部署你的php代码了
    为什么大多数培训机构还停留在只教ssh框架?
    设置spring-boot的logging
    ElasticSearch 429 Too Many Requests circuit_breaking_exception
    LINUX下永久添加静态路由
    Kafka集群管理和监控方案之Kafka Manager
  • 原文地址:https://www.cnblogs.com/goody9807/p/1377161.html
Copyright © 2011-2022 走看看