国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > HTML > 正文

從gb到utf-8

2020-10-23 18:47:21
字體:
來源:轉載
供稿:網友

現在不少中文網站的編碼都在從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);
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 阆中市| 修武县| 汶川县| 安新县| 绥德县| 陆良县| 西平县| 潜山县| 娄烦县| 镇宁| 龙南县| 吴桥县| 凤台县| 南澳县| 华池县| 本溪| 山西省| 密山市| 江口县| 邳州市| 濉溪县| 尉犁县| 秀山| 湘西| 新化县| 吕梁市| 莆田市| 柳林县| 永寿县| 隆昌县| 新泰市| 绥阳县| 如东县| 中超| 公主岭市| 普定县| 舒兰市| 游戏| 阿拉善盟| 灵丘县| 平武县|