微型PHP框架:MicroPHP
MicroPHP是一个免费、开源、敏捷的MVC模式的PHP开发框架。它易拓展而不失灵活,可以轻松对应大中小型项目。MicroPHP没有大而全的功能,只给你最需要的底层功能,但是给你无限的灵活拓展能力。其它框架都有的基本特性这里就不一一罗列。
说一下MicroPHP的特性:
1. 整个框架核心就一个文件MicroPHP.php(压缩后的文件MicroPHP.min.php,140KB左右)。
2. 入口文件index.php也是整个项目的配置文件,一个入口文件就是一个项目的入口,可以自定义多个入口文件达到不同项目共存的目的,项目之间随意共享类库、帮助文件等目录,框架核心文件采用零侵入式编写,整个框架的运行不依赖任何外部变量,初始化的时候只要通过WoniuRouter::setConfig($system)
注入配置,然后WoniuRouter::loadClass()
执行即可。
3. 独特的插件模式:这是MicroPHP的一大特色,插件模式就是可以把框架嵌入到任何现有的程序代码到中,只要在使用前包含plugin.php(要保证 plugin.php和MicroPHP.min.php在一个目录)即可,然后按着MicroPHP框架的各种特性写代码,插件模式和正常模式唯一不同的就是插件模式下MicroPHP的路由功能不再使用,其它特性完全保留。
插件模式有用的有三个方法:
//使用默认数据库配置取得数据库ActiveRecord操作对象,然后可以$db->get('tablename')->result_array();这样去操作数据库。 (1).$db=WoniuLoader::instance()->database(null,true); /实例化一个welcome控制器,然后调用其doIndex方法 (2).WoniuController::instance('welcome')->doIndex(); //实例化控制器目录里admin文件夹下面的login控制器,然后调用其doIndex方法 WoniuController::instance('admin.login')->doIndex();//admin是文件夹 //实例化一个User模型,然后调用其add方法 (3).WoniuModel::instance('User')->add('snail');
可以看出当想使用MicroPHP的一些方便的功能时,比如数据库操作,这个时候不需要去实例化一个控制器或者模型,只要通过
WoniuLoader::instance()
返回的对象去获取即可。 WoniuController::instance($path)、WoniuModel::instance($path)
其中$path支持文件夹用点的方式引用。 当你现在开发的程序使用了一个不友好的框架或者干脆没有框架的时候,你每次编码都很痛苦,而且不能换框架或者修改程序结构,那么这个时候你只要引入MicroPHP,然后使用插件模式就能优雅方便的去写代码了。
5. 类库采用懒加载模式,只要按着规定命名规则,然后把你的类库文件扔到类库文件夹,在控制器或者模型中直接new 类库名()即可,系统会自动加载相应的类库文件。
6. 没有视图就不能指定视图数据?文件可以include共享那么视图为什么不能共享数据呢?在MicroPHP里面你不再有这个困挠,MicroPHP可以在
$this->view_vars
数组里面存放你的任何想在视图里面使用的全局数据。 特别是网站头部导航用户数据全站每个页面都用到,那么可以自定义个控制器父类,然后和在父类构造方法里面初始化这个用户数据,放到$this->view_vars
里面,那么所有的控制器再也不用重复的去取用户数据传给视图。 7. 灵活的session托管,支持的管理类型:
mongodb,mysql,memcache,redis
.当然也可以用系统默认的管理方式.session托管是可选的,根据项目具体情况择优选用即可。session托管的好处很多,比如:支持分布式、精确控制session过期时间,等等。 8. 灵活的缓存机制。
(1).可用的方式缓存驱动有:
auto,apc,sqlite,files,memcached,redis,wincache,xcache,memcache
。auto自动模式寻找的顺序是 : apc,sqlite,files,memcached,redis,wincache,xcache,memcache
。 (2).缓存配置有个第二驱动机制,比如:当你现在在代码中使用的是memcached, apc等等,然后你的代码转移到了一个新的服务器而且不支持memcached 或 apc这时候怎么办呢?设置第二驱动即可,当你设置的驱动不支持的时候,系统就使用第二驱动。
(3).易拓展的缓存驱动,如果上面的驱动类型还不能满足项目的缓存需求,那么可以拓展缓存驱动,驱动编写可以参考源文件里面的
cache-drivers/drivers/example.php
,10分钟就能写好你自己的驱动,接着在缓存配置$system['cache_drivers'] = array($example_file_path)
里面指定自己的缓存文件位置和"storage" => "example"
缓存类型即可,然后在项目中$this->cache
即可使用example缓存驱动。当然接着还可以自定义example驱动的第二驱动,比如:"fallback" => array("example" => "files")
,当系统环境不支持example驱动的时候使用第二驱动files。 项目主页:http://www.open-open.com/lib/view/home/1384437365383