UTF-8与GB2312编码页面乱码的解决

发布时间:2015年2月25日 作者:未知 查看次数:1598

UTF-8与GB2312编码页面乱码的解决


在使用UTF-8编码后,经常会无故出现乱码,后来想是数据库的问题。

 

同一网站UTF-8与GB2312两种编码页面避免乱码的方法 

自:http://blog.163.com/hlyluck@126/blog/static/51369005200910511595035/

以前一直用PJBLOG,现在使用独立主机安装了一个OBLOG。结果在从PJ转向O的页面时就会出现乱码,直接打开O,或者先打开O然后转向PJ都没有问题,只有从PJ转向O就会出现乱码。

在网上搜索了一些方法,一般的没有太大效果。总结了一些出现乱码的原因有如下几种可能:

1、GB2312页面没有在头部设置charset=GB2312

2、如果设置了charset=GB2312 ,尝试在ASP源码头部加上

复制内容到剪贴板 程序代码

    <%@LANGUAGE="VBSCRIPT" CODEPAGE="936"%>

    其中 936为GB2312 ; 65001为UTF-8

3、因为程序没有设置读取数据库时所使用的编码类型,所以打开数据库时就会直接读取上一次所使用的编码类型。如先打开UTF-8页面,数据库按照UTF-8读取数据库内容。而在此时您再打开GB2312页面时,因为没有设置服务器按照刚刚使用过的编码类型即UTF-8读取数据库。这就造成打开的页面内容除数据库内容外正常显示,所有数据库内容显示乱码的原因的。

    而我网站上所出现的问题也就是第三种,因为一般比较成熟的程序代码都会设置前两项,而第三项是大部分程序设计人员所忽略的。

解决方法也很简单只要在乱码的那个程序源代码设置一下就行了:

UTF-8设置方法(data/data.mdb为数据库地址)

复制内容到剪贴板 程序代码

<%

response.codepage=65001

response.charset="UTF-8"

set conn = server.CreateObject("adodb.connection")

on error resume next

conn.Open "driver={microsoft access driver (*.mdb)}; dbq=" & server.MapPath("data/data.mdb")

%>

GB2312设置方法(data/data.mdb为数据库地址)

复制内容到剪贴板 程序代码

<%

response.codepage=936

response.charset="GB2312"

set conn = server.CreateObject("adodb.connection")

on error resume next

conn.Open "driver={microsoft access driver (*.mdb)}; dbq=" & server.MapPath("data/data.mdb")

%>

 



版权所有!www.sieye.cn
E.Mail:sieye@sohu.com QQ:66697110