今天我终于开始自己写一个完整的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读出的数据不会出现乱码;