php导航下拉菜单乱码,php的部分乱码问题集的解决方法

本文记录了一位开发者从零开始编写PHP MVC模板系统的经历,作为其毕业设计的一部分。文中详细介绍了如何创建MVC结构,包括Model、View、Controller和DataAccess层,并着重讨论了在处理中文乱码问题上的解决方案。从新建PHP文件的正确方式到设置Dreamweaver的默认编码,再到MySQL的字符集配置,作者提供了避免和解决乱码的完整步骤。
摘要由CSDN通过智能技术生成

今天我终于开始自己写一个完整的web模板系统,是从零开始写起的,以前做网站都是通过网上下载一个模板,然后修改页面和部分动态代码,然后就ok了,但是今天不一样了,是从头开始,因而这个我的毕业设计,哈哈,没办法,我的毕业设计的题目是“基于php技术的企业网站的模板设计”,因而我今天开始写mvc的一些测试类,当然,首先从网上下载一个基于php的MVC留言本实例,这个实例有6个程序文件:分别是index.php程序入口,notebook.htm留言表单,然后新建一个文件夹,里面有Model.php,View.php,Controller三个文件分别实现MVC三个功能,还有一个DataAccess.php(是一个简单的数据库访问类),一开始我是通过系统右击新建文本文件来新建php文件的,这里需要提醒一下初学者,不要这样新建php文件,因为这样会导致中文乱码的,正确的方法是通过Dreamweaver新建,然后在导航菜单“编辑”->“首选参数”->“新建文档”里,把默认编码设置为“Unicode(UTF-8)”,“包括Unicode签名(BOM)”的复选框去掉,就可以解决在调用php类时,类中需要用到return方法来返回到静态页时,如果你不是按照以上的方式去做,有可能出现乱码;

乱码问题:

1、在index.php调用到View.php的方法时,在获取中文的时候出现乱码,解决方法,就是用Dreamweaver新建,按上述操作,可以解决乱码问题;

2、由于我用的是utf-8的字符集,所以mysql里也要设置为utf8的字符集,如mysql的连接校对:utf8_general_ci,而表里的字段的字符集是utf8_unicode_ci,在index.php的开头要写上,然后再DataAccess.php里如下所示:

class DataAccess {

var $link_id; //用于存储数据库连接

var $query_id; //用于存储查询源

//! 构造函数.

function __construct($host,$user,$pass,$db) {

$this->link_id=mysql_pconnect($host,$user,$pass); //连接数据库服务器

mysql_select_db($db,$this->link_id);              //选择所需数据库

mysql_query("SET NAMES 'utf8' ",$this->link_id);    }

function query($sql) {

$this->query_id=mysql_unbuffered_query($sql,$this->link_id); // Perform query here

if ($this->query_id) return true;

else return false;

}

function fetchRows($sql) {

$this->query($sql);

$arr=array();

$i=0;

while( $row=mysql_fetch_array($this->query_id,MYSQL_ASSOC) )   {

$arr[$i]=$row;

$i++;

}

return $arr;

}

}

?>

按照上面的操作基本你能解决从mysql读出的数据不会出现乱码;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值