以前一直用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")
%>
http://blog.163.com/hlyluck@126/blog/static/51369005200910511595035/