zoukankan      html  css  js  c++  java
  • Asp.net把UTF-8编码转换为GB2312编码

    系统采用的UTF-8编码,而一些支持系统使用的是GB2312编码。

    不同编码的页面、脚本之间互相引用,就会产生乱码的问题,解决方法就是统一成一种编码。
    asp.net 中,如果要修改输出页面的编码,可以通过修改web.config中以下配置信息


    <globalization requestEncoding="utf-8" responseEncoding="utf-8" />
    以上只是修改整体的默认编码,如果只有某个页的编码需要修改,ASP.net 中则可以简单的使用下面代码:


    注:加到Page_Load()事件下面就可以了
    Encoding gb2312 = Encoding.GetEncoding("gb2312");
    Response.ContentEncoding = gb2312;
    在非ASP.net 应用中,可能你读到的数据是UTF-8编码,但是你要转换为GB2312编码,则可以参考以下代码:

    string utfinfo = "document.write("alert('你好么??');");";
    string gb2312info = string.Empty;

    Encoding utf8 = Encoding.UTF8;
    Encoding gb2312 = Encoding.GetEncoding("gb2312");

    // Convert the string into a byte[].
    byte[] unicodeBytes = utf8.GetBytes(utfinfo);
    // Perform the conversion from one encoding to the other.
    byte[] asciiBytes = Encoding.Convert(utf8, gb2312, unicodeBytes);
               
    // Convert the new byte[] into a char[] and then into a string.
    // This is a slightly different apPRoach to converting to illustrate
    // the use of GetCharCount/GetChars.
    char[] asciiChars = new char[gb2312.GetCharCount(asciiBytes, 0, asciiBytes.Length)];
    gb2312.GetChars(asciiBytes, 0, asciiBytes.Length, asciiChars, 0);
    gb2312info = new string(asciiChars);

    当然,其他各种编码之间的转换,跟上述代码也类似的,就不描述了。

  • 相关阅读:
    SQL Function(方法)
    SQL Cursor(游标)
    SQL Proc(存储过程)/tran(事物)
    AAABBBBCCCC
    Visual Studio2012中搭建WCF项目
    关于抽象工厂模式
    C#面向对象的学习笔记
    休假回来 更博-MySQL以月为单位的客户综合情况表_20161008
    结合Mysql和kettle邮件发送日常报表_20161001
    MySQL-with rollup函数运用 _20160930
  • 原文地址:https://www.cnblogs.com/Brainpan/p/3178323.html
Copyright © 2011-2022 走看看