• 企业400电话
  • 网络优化推广
  • AI电话机器人
  • 呼叫中心
  • 全 部 栏 目

    网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    从gb到utf-8
    POST TIME:2021-10-18 08:28

    现在不少中文网站的编码都在从gb2312向utf-8编码转化。其中出现了不少问题在这里总结一下:

    前提:

    保证所有的文件保存的时候都是utf-8编码的,而不是ansi

    具体设置:如果使用的是文本编辑器,那么在保存文件的时候就有一个编码选择(图1) 将其选择成UTF-8就可以了。

    如果是使用的dreamweaver那么就麻烦一点。

    使用dreamweaver编辑静态文件时,那么将文件的charset标签修改成utf-8: meta http-equiv="Content-Type" content="text/html; charset=gb2312" />改为 meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 然后选择另存为这时候dream会将文件保存为utf-8编码的

    注:如果使用的是access数据库那么只需要以上两步就可以了,access本身采用utf-8编码。

    asp篇

    代码页设置:

    asp文件的第一行: %@LANGUAGE="VBSCRIPT" CODEPAGE="936"%> 改成: %@LANGUAGE="VBSCRIPT" CODEPAGE="65001"%> 这也直接决定了asp 通过ado访问数据库采用的编码。
    注:如果使用的是access数据库那么只需要以上两步就可以了,access本身采用utf-8编码。

    如果使用了模板程序

    通常的模板程序,通过fso对象来读写文件。但是这种方式没法支持utf-8,需要改成stream对象来读写文件,下面是几行关键的代码:
    使用stram读文件
    Set objStream = Server.CreateObject("ADODB.Stream")
        With objStream
        .Open
        .Charset = "utf-8"
        .Position = objStream.Size
        .LoadFromFile server.mappath("sc.htm")
        wstr = .ReadText
        .Close
        End With
    Set objStream = Nothing
     
    使用stream写文件Set objStream = Server.CreateObject("ADODB.Stream")
        With objStream
        .Open
        .Charset = "utf-8"
        .Position = objStream.Size
        .WriteText=wstr
        .SaveToFile server.mappath("wz/sc_" classid ".htm"),2 
        .Close
        End With
    Set objStream = Nothing

    php篇

    php与access连接:

    在windows主机上 使用php的com扩展可以连接access数据库,在建立ADODB.Connection的时候 指定代码页参数为65001

    ?php
    $conn = new COM("ADODB.Connection",NULL,65001) or die("ADO connect failed!");
    $rs = new COM("ADODB.RecordSet") or die("ADO recordset fail"); $conn->open("Provider=Microsoft.Jet.OLEDB.4.0;Data Source=data.mdb");
    $rs = $conn->Execute("select * from data");
    while not $rs->EOF
    echo $rs->Fields['title']->value;
    ?>

    php 与mysql连接

    与mysql数据库建立好连接后首先执行以下SQL查询:

    ?php  mysql_query("SET NAMES 'utf8'");  ?>

    mysql手册  关于set names 的说明 SET NAMES显示客户端发送的SQL语句中使用什么字符集。因此,SET NAMES 'cp1251'语句告诉服务器“将来从这个客户端传来的信息采用字符集cp1251”。它还为服务器发送回客户端的结果指定了字符集。(例如,如果你使用一个SELECT语句,它表示列值使用了什么字符集。)
    SET NAMES 'x'语句与这三个语句等价:

    mysql> SET character_set_client = x;
    mysql> SET character_set_results = x;
    mysql> SET character_set_connection = x;
    将x设置为character_set_connection也就设置了collation_connection是x的默认校对规则。

    使用adodb类:

    设置'charpage' 属性为65001;

    ?php
    require_once('adodb/adodb.inc.php');
    $conn = ADONewConnection('ado_access');
    $conn->charPage ='65001';
    //$conn->charPage = 65001;
    //$conn->debug = true;
    $dsn = sprintf("Provider=Microsoft.Jet.OLEDB.4.0;Data Source= %s",realpath('2data.mdb'));
    // $dsn = sprintf("Driver={Microsoft Access Driver (*.mdb)};Dbq=%s",realpath("data.mdb"));
    $conn->Connect($dsn);
    上一篇:调用265天气预报,不显示链接
    下一篇:html在线编辑器的更新[2006-05]
  • 相关文章
  • 

    关于我们 | 付款方式 | 荣誉资质 | 业务提交 | 代理合作


    © 2016-2020 巨人网络通讯

    时间:9:00-21:00 (节假日不休)

    地址:江苏信息产业基地11号楼四层

    《增值电信业务经营许可证》 苏B2-20120278

    X

    截屏,微信识别二维码

    微信号:veteran88

    (点击微信号复制,添加好友)

     打开微信