v2.0 稳定版,没有使用命令空间,5.3以下使用
SlightPHP 高效的PHP敏捷开发框架
主要特点:
- 独有的"框架"与"plugins"分离方式,与现在主流框架完全不同,把核心框架与其它功能独立分开,灵活性大,耦合度小,很方便移植
- v3.0支持composer管理和加载
- 支持命令行模式,只需要在执行代码里时定义 $_SERVER['REQUEST_URI'] 的值,就可以简单通过命令行执行框架代码和逻辑
- 框架本身核心代码非常小,速度快效率极高,更支持php模块方式加载(请编译pecl目录下的源码,或者直接编译到php里)
- 框架支持nginx,lighttpd,apache,iis等web服务器
- 插件SDb 支持mysql,mysqli,pdo,mssql,oracle等主流数据库,同时更支持数据库读写库分离,特适合大流量网站
- 插件SRoute 支持各种简洁路由支持,精简URL
- 插件STpl模板类,高效与灵活,比Smarty轻量级不少!
- 插件SCache(memcache)采用consistent hashing算法,支持分布式服务与依赖KEY,同时也支持file,apc缓存
- 其它更多灵活可定制的插件,请查看wiki或者samples下的例子
Hello, world!
第一步
在网站根目录下,建立index.php
<?php
//加载方式1,直接加载框架
require_once("SlightPHP.php");
//加载方式2,使用扩展,或者直接编译进PHP也可以
//dl("slightphp.so");
//或者在php.ini里增加(如果不支持dl的话)
//extension = slightphp.so
//加载方式3,使用composer的autoload
//require_once("vendor/autoload.php");
SlightPHP::run();
?>
第二步
第二步 请在index.php所在目录下新建zone目录,在zone目录下新建page.page.php
<?php
class zone_page{
function PageEntry($inPath){
echo "Hello, world!";
}
}
?>
第三步
请在你的地址栏里访问index.php,如
http://localhost/index.php
基本概念
zone 映射为一个目录名,默认为"zone"
page 映射为一个文件名,以.page.php为扩展名,默认为"page"
entry 映射为方法名,以Page开头的方法名,默认为"entry"
appDir 应用程序目录,默认为".",就是当前目录
splitFlag 分割符,默认为"/"
inPath entry入口参数,数组,下面会有更详细的介绍
地址解析
这个地址 http://localhost/index.php 实际上和 http://localhost/index.php/zone/page/entry 一样
会执行你的$appDir/zone/page.page.php下的pageEntry方法
你可以改变其默认规则
<?php
SlightPHP::setDefaultZone("user");
SlightPHP::setDefaultPage("profile");
SlightPHP::setDefaultEntry("update");
?>
当访问 http://localhost/index.php 时,就会执行
$appDir/user/profile.page.php里的pageUpdate方法,其实就是
http://localhost/index.php/user/profile/update
这个URL
高级地址解析-别名
如果加了这代码
SlightPHP::setZoneAlias("user","u");
你访问这个地址
http://localhost/index.php/u/profile/update
和http://localhost/index.php/user/profile/update
会是一样的效果
它的作用是增加user一个别名u
分隔符(splitFlag)
zone,page,entry的分隔默认是用/来分的,你可以改成自己想要的,如
SlightPHP::setSplitFlag(".")
就可以这样访问了
http://localhost/index.php/user.profile.update
或者更好看,加上.html
http://localhost/index.php/user.profile.update.html
这样的方式你也可以这样,用多个分割符
SlightPHP::setSplitFlag("-.")
http://localhost/index.php/user-profile-update.html
和上面的是一样
Apache Rewrite
在你的.htaccess里或者apache的配置文件里加下类似代码
RewriteEngine on
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME} !-d
RewriteRule ^(.*)$ index.php/$1 [L]
你就可以直接这样访问了
http://localhost/user/profile/update
如果你还加上了
SlightPHP::setSplitFlag(".");
那么就可以用这样的方式 http://localhost/user.profile.update
短路由
如你要直接这样,更短的地址
http://localhost/profile/update
请在apache的配置文件里加上类似这样的代码
RewriteRule ^(/profile/.*)$ /index.php/user/profile/update/$1 [E=PATH_INFO:$1,L]
关于$inPath
- $inPath[0] 就是当前的 zone的名字
- $inPath[1] 就是当前的 page的名字
- $inPath[2] 就是当前的 entry的名字
- $inPath[...] 超过以前的就是后面更多的参数,如html
如 http://localhost/index.php/user/profile/update/other1/other2/... inPath是这样的
$inPath=array("user","profile","update","other1","other2","...")
appDir,程序目录设置
你可以自定义你的程序目录
SlightPHP::setAppDir("/home/www/myAppdir");
如http://localhost/index.php/user/profile/update
就会执行
/home/www/myAppdir/user/profile.page.php下的pageUpdate方法
建议你的appDir目录不要让外部访问到
插件导航
文档地址:https://github.com/hetao29/slightphp/tree/master/wiki
STpl 模板插件 https://github.com/hetao29/slightphp/blob/master/wiki/STpl.md
SDb 数据库插件 https://github.com/hetao29/slightphp/blob/master/wiki/SDb.md
SCache 缓存Memcache,File,Apc插件 https://github.com/hetao29/slightphp/blob/master/wiki/SCache.md
SRedis 缓存Redis插件 https://github.com/hetao29/slightphp/blob/master/wiki/SRedis.md
SConfig 配置文件插件 https://github.com/hetao29/slightphp/blob/master/wiki/SConfig.md
SRoute 路由插件 https://github.com/hetao29/slightphp/blob/master/wiki/SRoute.md
SError 错误插件 https://github.com/hetao29/slightphp/blob/master/wiki/SError.md
...
更多插件功能请看samples下的示例
Nginx配置
location / {
root /var/www/slightphp/samples/www;
index index.php;
if (!-e $request_filename){
rewrite ^/(.+?)$ /index.php last;
}
}
location ~ \.php$ {
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME /var/www/slightphp/samples/www$fastcgi_script_name;
include fastcgi_params;
}
Version
2.0.1 beta
Free Software, Hell Yeah!