MVC
代码的管理,代码级项目构架,依据代码的类型(功能),将代码分门别类的存储在不同的文件中。
目前比较主流的管理方式,依据代码的功能,将代码分成三大类,分别用M,V,C来表示,简称为MVC项目架构思想。
M:model 模型
数据业务逻辑处理,会返回处理好的数据 可以暂且理解为从数据库取出数据V:view 视图
直观的图形界面c:controller 控制器
向系统发出指令的工具和帮手
mvc工作流程
请求->入口->控制器->模型->视图->输出
第一步 浏览者 调用控制器,对他发出指令
第二步 控制器 指令选取一个合适的模型
第三步 模型 按控制器指令取相应数据
第四部 控制器 按指令选取相应视图
第五步 视图 把第三步取到的数据按用户想要的样子显示出来
必要的特点:
浏览器仅仅会请求控制器,从控制器获取相应结果。意味着所有url地址都是请求某个c才可以
模型和视图都被控制器调用
模型和视图不需要完成任何的交互
通常一个表对应一个模型
前端控制器(入口文件)
index.php,用来实例化控制器对象,并调用方法动作的文件,称之为:前端控制器,负责分发参数,也被成为请求分发器,将请求分发给某个控制器的动作执行机器。
还被称之为入口文件,指定是只要该项目的功能,都需要经过index.php完成。
如何使前端控制器,能够做到可以在 任意控制器类 的 任意动作 一个前端控制器就够了,所有功能都由该前端控制器来执行!
逻辑上,区分开当前应该执行那个控制器的那个方法动作,通过请求index.php时,向其传递get参数的方式完成:
例如:
index.php?c=控制器&a=方法名
参数哪来的?生成连接地址时,已经生成好了,浏览器用户只需要点击操作即可!额外的,通常会有默认功能,默认的控制器和默认的动作。
将当前的控制器名 动作名,通常会选择存储在常量中的原因:
- 保证该次请求脚本周期内,当前的值不变。
- 每次请求由控制器和动作来决定执行哪个功能
使用,凡事需要使用当前控制器名,和当前动作名的地方,都是以上定义好的常量即可
路径
相对路径:相对于当前位置的路径标示方式。
核心问题:确定当前的位置
当前位置(当前工作目录)确定,过程:
浏览器请求web服务器,web服务器交由php核心处理php脚本,当php核心程序处理php脚本时,需要确定当前工作目录(CWD current working drectort),就是当前目录,确定原则,php核心执行的第一个执行位置
当前工作目录,直到脚本周期结束,或者人为更改才会变更。意味着,常规的情况, 当前工作目录,永远是url请求的脚本所在路径,而不取决于,载入哪个文件。
getcwd()获取当前工作目录。
自定义框架
基础代码(model,mysqldb)与功能(controller,matchmodel)相分离
- 基础代码:所有项目都可以使用,框架代码。
- 功能代码:具体实现当前项目某个功能的代码
框架、功能代码分离
例:
app(功能代码,应用程序)
framework(基础代码,框架代码)[工厂类,模型类,mysql数据库类]
功能代码模块划分,module
功能模块,也叫平台,控制器分组,指的是:功能大的集合
例:
前台模块和后台模块
app目录中,划分多个模块
home,admin,wechat,mobile,debug,alpha,meta,test
比较特殊的 common(公共[配置,函数])
mvc的划分
在模块中划分model,view,controller中
mvc框架
例如时下比较流行的 thinkphp yii laravel
框架:基础结构和基础代码的集合,不包含业务逻辑的实现,基础代码可以用于任何业务逻辑中。
mvc框架:采用框架实现功能时,需要满足mvc的代码管理架构思想,则该框架九尾mvc框架。(提供一定的功能以外,还需要有基础的结构)
m 模型层的实现
典型的框架都会采用面向对象的思想开发
具体的某个模型,就是某个模型的实例(对象)
结构如下:
每个数据库中需要操作的数据表,会对应项目中的一个模型。
需要操作多张表的情况,在主要数据对应表中操作。
基础模型类 model-模型对象要实现单例化-工厂模式
c 控制器的实现
深度使用面向对象的思想
将一类相关的操作,封装在一个控制器中,每个操作,就是一个控制器方法,称之为动作action
目前的做法,每个功能在一个控制器文件,例如 match_c team_c,该设计会带来控制器文件过多(增删改查),需要将相关的一系列功能,整合到一个控制器文件中
index.php入口文件
通常会放在项目根目录(documentroot)中,浏览器仅仅回去请求入口文件
/根目录
|---app/应用程序目录
|---home/前台
|---m/
|---v/
|---c/
|---admin/后台
|---common/公共目录
|---framework/框架基础目录
|---mysqlDb.class.php
|---factory.class.php
|---model.class.php
index.php入口文件
修改载入文件路径-保证运转
http://localhost/index.php?module=home&controller=user&action=login&var=value
直接请求,通过错误提示修改
类文件的自动加载
类名与类文件地址关系如下:
其一:框架中所有的类,可以完全确定的类。框架一旦定义好了,类确定了。
采用类名与文件位置映射表(速度快)
其二:应用程序中app模型和控制器类,适应不同功能而变化。
采用固定规则进行加载。
模型类:Model结尾 在当前模块目录中存储
控制类:Controller结尾 在当前模块下controller子目录,以类名.class.php结尾
编码实现:
index.php中,定义自动加载方法
//自动加载实现
spl_auto_register('xxx');
$classlist = array();
类文件地址映射表,定义在方法外没保证定义一次,以为会被调用多次
function xxx($classname){
//映射加载
$classlist = $_GLBALS['classlist'];
if(isset($classlist[$classname])){
require $classlist[$classname]
}elseif('Model'==substr($classname,-5)){
require './app/'.MODULE.'/model/'.$classname.'Model.class.php';
}elseif('Controller'==substr($classname,-10)){
require './app/'.MODULE.'/controller/'.$classname.'Controller.class.php';
}
//规则加载
}