框架详解


正如在框架设计的初心上所说,市面上已经那么多的框架了,还造什么轮子,再次重申一下。造轮子不是目的,造轮子的过程中汲取到知识才是目的,共勉。

框架的组织方式

kickpeach项目目录参考Laravel的文件组织方式进行组织,采取组件化开发,灵活扩展升级每个组件,主要由以下几个组件完成:

可查看组织进行源码的阅读

kickpeach 
        kickPeach----> 最终可以使用的框架
        framework----> 框架的核心文件
        queue----> 任务队列组件
        database----> 数据库组件
        mdCalls----> 提供模块化服务的组件
        kickpeach.github.io---->框架的使用文档

其他模块都有模块的文档

框架的设计思路


入口文件
        ----> 注册错误(和异常)处理函数
        ----> 加载配置文件
        ----> 请求
        ----> 路由 
        ---->中间件
        ---->(控制器 <----> 数据模型)
        ----> 响应
        ----> 视图渲染数据
  • 阅读源码的方式

    composer create kickpeach/kickpeach testkickpeach,composer update下载载源码下来之后,按照上面流程,可以看到框架源码的具体实现,从index.php入口看起。kickpeach只是framework的扩展,基于framework,完全可以自定义有自己风格的框架。 核心源码都在framework,在看源码的时候,你就会深入了解到什么叫self,static,继承,抽象,与接口。

  • 模块化组织 个人觉得Laravel的容器太重,虽然好用,但是还是不太想用这个,因此,这里使用了MdCalls组件来解决依赖方式,可见框架中mdcalls目录,mdcalls支持rpc与框架内调用,内置了database,queue以及redis服务,具体使用方式可见文档

  • 自动加载

    使用composer和命名空间,遵循psr-4规范

  • 异常模块

    错误捕获,异常捕获,让错误可以被异常一样捕捉,并且友好的提示错误,关键函数set_error_handler,set_exception_handler,register_shutdown_function

  • 路由 解析请求,基于fastroute组件开发,支持自定义路由以及默认路由,为了不占内存,缓存了路由,获得待处理的的模块,控制器和方法

  • 控制器 获取每个控制器定义的中间件,先经过中间件解析处理,最后才控制器

  • 中间件 借鉴了Laravel的pipeline编写了路由中间件

  • 响应 模板引擎使用twig组件,支持变量赋值以及模板,支持json响应

  • 数据库 采用第三方database组件方式,利用mdcalls提供服务

  • 其他友好函数 日志工具类,文件读取文件,日志读取类,配置文件读取类

  • queue 任务队列组件,支持延时队列以及失败任务重试

TODO

  • [ ] 请求参数的验证模块
  • [ ] 集成php-debugbar
  • [ ] 使用kickpeach做一个demo

帮助kickpeach改进

欢迎给Kickpeach提issue:https://github.com/KickPeach/kickPeach/issues