PHP使用UTF8编码读取ACCESS的乱码问题解决方案
taotaoit PHP 2017-06-09 3117 0
关于本站

“最难不过坚持”

本人承接扒站仿站,php网站维护,病毒查杀,网站编辑,网站改版,html制作

有需要网站维护,改版,病毒查杀,网站编辑,网站备案,html制作等相关的工作可以联系我。
本人有多年相关工作经验,也可提供免费咨询,交个朋友。
有需要探讨问题的朋友,也可以加我微信,共同探讨!
微信:15011482830 QQ:408917339

7440977 2655 39
最新评论
https://jueru.net/
评 留言
:weixiao:
评 留言
:shuijiao: :weiqu: :zhenbang: :leng:
评 留言
:yiwen: :yiwen: :yiwen: :yiwen:
评 EasySass: could not generate CSS file. See Output panel for details.
这个业务逻辑多少都有点奇怪了,阅读浏览次数增值在新闻详情页的控制器方法里setInc,这怎么还写进模型事件里了。如果非要用onAfterRead也可以,把新闻文章的内容单独分出来一个news_content表,然后把它和news做关联,然后给news_content表的onAfterRead事件做增值处理,这样点进新闻页内查询到文章内容时才会触发它。
评 TP6模型事件-查询后onAfterRead不好用
文章标签更多
ThinkPHP (254)
Mysql (58)
DedeCms (33)
jQuery (67)
证件照 (1)
setInc (4)
setDec (4)
onclick (5)
打开边栏(ESC) 关闭边栏(ESC)

用php连接access数据库,当页面编码是utf-8的时候,就会出现乱码。

下面给出解决办法

一、读取数据

使用 iconv函数制作一个转码的自定义从GBK转到UTF-8的函数,如以下代码:

//从GBK转到UTF-8,输出的时候用
function enc($c){
	return iconv('gbk','utf-8',$c);
}
二、添加数据

为了写入数据库的编码是符合数据库需要的,所以我们还要制作一个从UTF-8转向GBK的函数:

//从UTF-8转向GBK,添加的时候用
function dec($c){
	return iconv('utf-8','gb2312',$c);
}
制作好了转码函数,接下就是正常使用了。在从数据库里面调数据显示在页面的时候使用enc()函数,从页面提交数据到数据库时使用dec()函数,这样就可以很好的解决PHP使用UTF-8编码,ACCESS使用系统默认编码的问题了。


应用实例代码

<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
<?php
header("content-type:text/html;charset=utf-8");
//从GBK转到UTF-8,输出的时候用
function enc($c){
	return iconv('gbk','utf-8',$c);
}
/* 
   创建ADO连接 
*/
$conn = @new COM("ADODB.Connection") or die ("ADO Connection faild."); 
$connstr = "DRIVER={Microsoft Access Driver (*.mdb)}; DBQ=" . realpath("ycxfbase.mdb"); 
$conn->Open($connstr); 
/* 
创建记录集查询 
*/
$rs = @new COM("ADODB.RecordSet"); 
$rs->Open("select * from about",$conn,1,3); 
/* 
   循环读取数据 
*/
while(!$rs->eof){ 
	echo enc($rs->Fields["title"]->Value); 
	echo "<br/>"; 
	$rs->Movenext();     //将记录集指针下移 
} 
$rs->close();  
?>

版权声明:本站原创文章,允许自由转载。

相关推荐
php实现ZIP压缩文件解压缩,中文乱码解决方法(重要)
PHP | 2019-04-30 6233
直接上代码,具体代码里面都有注释。直接中文压缩文件解压到中文文件夹。 <?php // 需开启配置 php_zip.dll // phpinfo(); header("Content-type:text/html;charset=utf-8"); /* * $filename 被解压文件名 * $path 解压...
openssl_private_decrypt解密失败
PHP | 2019-01-16 6012
复制别人的解密程序,原程序可以解密,复制过来就不可以 一步步尝试发现,秘钥换行符有区别, 原秘钥有换行符,复制过来不知道什么时候把换行符清空了,成了一行字符串了。
评论:0条
评论加载中...
发表评论