zoukankan      html  css  js  c++  java
  • ASP.NET页面通过URL传递参数(一)(转载)

    解决的方法一般有3种:

    1.设置web.config文件

    <system.web>
    ......
    <globalization requestEncoding="gb2312" responseEncoding="gb2312" culture="zh-CN" fileEncoding="gb2312" />
    ......
    </system.web>

    2.传递中文之前,将要传递的中文参数进行编码,在接收时再进行解码。
    >> 进行传递

    string Name = "中文参数";
    Response.Redirect("B.aspx?Name="+Server.UrlEncode(Name)) ;

    >> 进行接收

    string Name = Request.QueryString["Name"];
    Response.Write(Server.UrlDecode(Name)) ;

    3.如果是从 .HTML 文件向 .Aspx 文件进行传递中文参数的话(即不从后台用 Redirect()方法进行 Url 转换)。一样要将传递的中文参数进行编码,在接收时再进行解码。
    >> 进行传递

    <script language="JavaScript">
    function GoUrl()
    {
    var Name = "中文参数";
    location.href = "B.aspx?Name="+escape(Name) ;
    }
    <body onclick="GoUrl()">


    >> 进行接收

    string Name = Request.QueryString["Name"];
    Response.Write(Server.UrlDecode(Name)) ;
    总结:
    一般来说。设置web.config文件就可以了。但是如果你用 JavaScript 调用 webservice 方法的话(往webservice里面传递中文参数)。设置 web.config 文件好象无效。
    或用

    Response.Redirect("test1.aspx?111="+System.Web.HttpUtility.UrlEncode(" 中华人明共和国")) ;
    //建议使用最后如果是从其他的页面获取中文参数没有乱码,那就更简单了

    string message ="http://localhost/Test/test1.aspx?111="+System.Web.HttpUtility.UrlEncode(" 中华人明共和国");

    http:
    //你要获取某个页面的返回值的地址"
    //发送请求
    HttpWebRequest myHttpWebRequest = (HttpWebRequest)WebRequest.Create(message) ;
    //接受请 求
    HttpWebResponse myHttpWebResponse = (HttpWebResponse)myHttpWebRequest.GetResponse() ;
    Stream receiveStream = myHttpWebResponse.GetResponseStream() ;
    StreamReader readStream = new StreamReader(receiveStream, System.Text.Encoding.GetEncoding("GB2312")) ;
    //此为要取页面的返回值输出的返回结果
    returnValue = readStream.ReadToEnd();

    转自:http://blog.csdn.net/faunjoe/archive/2009/09/26/4596826.aspx

    在对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即可。 

  • 相关阅读:
    c 的内存分配与释放原则: 通常应遵循“谁malloc,谁free”的原则。
    总算知道怎样从ImageMagick生成的数据转换成HICON: MagickGetImageBlob & LookupIconIdFromDirectoryEx
    收藏:Non-direct与direct ByteBuffer区别
    java NIO 直接与非直接缓冲区
    [收藏]:[算法]LRU和LFU的区别
    异步IO的并发能力:backlog的配置很重要
    ByteBuffer: 当由一个byte[]来生成一个固定不变的ByteBuffer时,使用ByteBuffer.wrap(byte[]);
    ByteBuffer的allocate与allocateDirect2013-01-11
    Windows完成端口与Linux epoll技术简介
    Java并发——Fork/Join框架与ForkJoinPool
  • 原文地址:https://www.cnblogs.com/johnwonder/p/1711748.html
Copyright © 2011-2022 走看看