zoukankan      html  css  js  c++  java
  • C#/ASP.NET对URL中的中文乱码处理

    前言:UTF-8中,一个汉字对应三个字节,GB2312中一个汉字占用两个字节。 不论何种编码,字母数字都不编码,特殊符号编码后占用一个字节。

    1、直接在C#后台编码URL参数

    引用类库:System.Web.dll

    编码:HttpUtility.UrlEncode(“要编码的中文参数”,System.Text.Encoding.UTF8)后面参数指定编码的字符集。

    解码:HttpUtility.UrlDecode(“要解码的字符串”,System.Text.Encoding.UTF8)后面参数指定解码的字符集。(注意解码和编码的字符集格式要一致,这里是System.Text.Encoding.UTF8

    按照GB2312进行编码 
    string tempString1 = System.Web.HttpUtility.UrlEncode("要编码的中文参数",System.Text.Encoding.GetEncoding("GB2312"));

    按照GB2312进行解码:

    string tempString2 = System.Web.HttpUtility.UrlDecode(tempString1,System.Text.Encoding.GetEncoding("GB2312"));

    2、在ASP.NET中可以使用下面方式

    编码
    string state=Server.UrlEncode(“要编码的参数”);
    Response.Redirect("aaa.aspx?state="+state+"");
     
    解码

    string state= Server.UrlDecode(Request.QueryString["state"].ToString());

  • 相关阅读:
    轻松完成mysql4.1与mysql4.0数据库转换备份
    MYSQL数据迁徙tips,ORA00907: missing right parenthesis
    viking病毒再次感染公司LAN
    [恢]hdu 2032
    [恢]hdu 2042
    [恢]hdu 2033
    [恢]hdu 2039
    [恢]hdu 2029
    [恢]hdu 2010
    [恢]hdu 2016
  • 原文地址:https://www.cnblogs.com/xiesong/p/6834418.html
Copyright © 2011-2022 走看看