[toc]
出发点:我个人理解 自己开发框架也是锻炼原生的一种手段。写完之后看别的框架也方便多了。如果你遇到一个没有文档或文档极少的框架,可以跟着这个思路摸索着补充。或干脆拿着原生上来就是干,我刚接触yii2的时候就是这样,都没来的及看文档就开工了,基本纯原生写的,就用了个yii2的csrf和双语言...
>[info]源码下载地址:https://github.com/yxgg/-frame
## :-: **写框架的 极简思路**
接收,打印参数想怎么弄。如 获取配置文件的方法,根据传过来的参数 构想
1、一般都是先判断文件是否存在。存在就该include就include,该new就new。然后存到对象的属性中(做缓存)
2、主要是调用流程:都什么需要放到run方法中
## :-: **详细思路**
![](https://box.kancloud.cn/dd777d133bbdf1d1747f6fe0a3d54f1d_484x223.png)
### :-: **1、写入口文件**
- 第2步-第5步都是写在入口文件中的
### :-: **2、定义常量**
- 就是框架的各层级目录,省着每次写一大串
```
//定义框架根目录
//定义核心文件目录路径
//应用目录(包含控制器、模型等)
//是否开启调试
//如果DEBUG为true,将错误
```
### :-: **3、引入函数库**
```
//加载公共方法
//加载核心文件
```
### :-: **4、自动加载**
~~~
判断要加载的类是否存在。提示:要加载的类已经存到属性中了,其实拿这个属性判断。
存在返回true;
不存在就加载。提示:加载时反斜线替换
要加载的是文件,就include。注意:这个文件从根目录下找
要加载的不是文件,就返回false
~~~
>[warning]注意:写完再建立lib目录,引入路由类。测试
### :-: **5、启动框架**
```
//调用核心文件中的run方法(我的核心文件是core/init.php)
```
### :-: **6、路由解析三部曲(分3个步骤)**
6.1、隐藏入口文件
6.2、获取url的参数
~~~
存在,就解析
正常情况,先转数组(方便处理),效验非正常情况(如:只在url上输入了控制器,没有输入方法,给方法个默认值)
处里url上的多余参数
正常情况
非正常情况,他输入的是奇数
非正常情况下,返回错误,写入日志 等
不存在给默认值。如 跳转到首页
~~~
6.3、返回对应的控制器和方法(其实在6.2中存到属性中,也算是返回了)
### :-: **7、加载控制器**
- 在run()时就要加载控制器
- 将路由解析出来的控制器名,拼成控制器文件的路径。
- 判断控制器文件是否存在,存在就new。不存在就抛出错误
>[info]这里引入了模块的概念\\app是模块不是应用,比成熟的框架少一层
### :-: **8、返回结果**
- 跑起来试一试,其实到这步一个建档的框架已经完成了。接下来的是扩展框架
### :-: **9、在控制器中连接模型类**
- 在lib中建立个model类,用于连接数据库
- 在控制器中new model类,写sql操作数据库
### :-: **10、中写视图类**
- assign和display方法写在初始化(core/init.php)类中。
>[info]先赋值,后包含模板文件
- 然后控制器继承该类,进行调用。
### :-: **11、写配置类**
新建配置文件类
写单个配置文件的方法(提示:既然他俩获取,传参是少不了的。2个参数,配置项,配置文件名。打印参数,然后构想)
//1、判断配置文件是否存在,存在就include
//2、判断配置项是否存在,存在直接给缓存到属性中
//3、判断属性中有无缓存,有就直接返回属性中存的
写获取所有配置文件的方法
>[info]新建个配置文件目录,用来放各种配置文件(如 数据库的,路由的,日志的....)
测试:配置文件好使不
### :-: **12、写日志类**
- 提示:用的是工厂模式的思想:
- 读取配置文件,获取当前驱动。在初始化方法中new类
- 在log方法中,调用不同驱动中的log方法
```
//建立日志类
//建立驱动目录
//建立日志的配置文件
```
### :-: **13、使用composer**
>[info]在自己的框架上,编写json文件,这样放到github上之后,别人就可以通过name名“xgkj”来使用composer下载了。
![](https://box.kancloud.cn/4e8b1359429120c24ef52d8a94d08676_497x184.png)
- 第1个"报错"类库的下载地址:https://github.com/filp/whoops
- 第2个“酷炫打印变量”类库的下载地址:
```
"symfony/var-dumper":"*" #更帅气变量输出的效果
"ymfony/var-umper":"*" #更帅气变量输出的效果
```
- 第3个“数据库”类库的下载地址:http://medoo.lvtao.net/1.2/doc.php
- 第4个“模板引擎”类库的下载地址:https://twig.symfony.com/doc/2.x/intro.html#installation
![](https://box.kancloud.cn/8af76a132d30e20395756f575bc52970_496x252.png)
镜像网址:[https://pkg.phpcomposer.com/](https://pkg.phpcomposer.com/)
![](https://box.kancloud.cn/9b4d423430c7b5581a60225673d0c529_473x335.png)
![](https://box.kancloud.cn/23a42285cb904579f61fe0aaf6f6cb94_492x268.png)
注意:下图很重要
![](https://box.kancloud.cn/ed4992ae1be30a207027a02356270d78_496x172.png)
![](https://box.kancloud.cn/ac9fa73224efc028ef1e198b9c877b7d_484x288.png)
### :-: **14、使用medoo数据库类**
- 如果自己封装pdo可能会有什么想象不到的漏洞,这样我们就不如直接用现成的类库加载http://medoo.lvtao.net/
```
//先将原来继承的pdo换成该类库
//在封装模型控制器调用
```
### :-: **15、模板引擎类库**
```
//修改display方法,改成类库的,还有模板布局
```
### :-: **16、其余扩展**
- 剩下其余的扩展就因人而异了,想不到的话,可能去参考成熟的框架
- 这里写2个封装好的方法
- 封装post接收方法(给大家做参考思路)
![](https://box.kancloud.cn/d9852a7d2858fdf61687993d62ffdfe1_495x51.png)
![](https://box.kancloud.cn/32dd9c4550a24904becd88c1c9a5c92a_496x370.png)
- 封装跳转方法
![](https://box.kancloud.cn/45c30ab07af57a1e91efa709f40bb17d_427x105.png)