Heim >Backend-Entwicklung >PHP-Tutorial >PHP 框架:Gaeaphp

PHP 框架:Gaeaphp

WBOY
WBOYOriginal
2016-06-20 12:58:131211Durchsuche

Gaeaphp 是一个基于 flightphp 的 PHP 框架

基础

环境要求

php 5.4+

安装

  • WebServer,具体配置方法参见Flight按照要求

  • Php-Memcached扩展,具体配置方法参见pecl

结构设计

项目目录结构

|-app/
|   ?|-configs/    配置文件夹
|   ?|-bootstrap.php   引导文件
|-src/      代码目录
|   ?|-libs/       类库方法库
|   ?| ?|-classes/
|   ?| ?|-functions/
|   ?|-modules/    模块文件夹
|   ?| ?|-xxxmodules/
|   ?| ?| ?|-controller/
|   ?| ?| ?|-libs/
|   ?| ?| ?|-model/
|   ?|-templates/
|   ?| ?|-default/
|-temp/     临时目录
|   ?|-caches/
|   ?|-compiled/
|   ?|-logs/

url访问

框架采用mvc设计模式开发,采用单一入口方式部署和访问。访问示例

http://yourdomain.com/module/controller/action/param1/param2

其中将会访问

/src/module/controller.php下的action方法

引导文件

/app/bootstrap.php引导文件完成了命名空间的注册,扩展模版引擎,以及路由的注册。
其中常量定义:
ROOT_PATH?系统根目录
APP_PATH?app目录
TEMP_PATH?临时目录
SSRC_PATH   ? 系统代码目录
WEB_PATH    ? 系统WEB资源目录

系统配置

所有的配置文件均已数组形式返回。具体配置文件项在/app/configs下
|-db.php    数据库(Mysql)配置文件
|-memcache.php       缓存(Memcache)配置文件
|-route.php     路由配置文件
|-smarty.php    模版引擎配置文件
|-system.php    系统配置文件

系统配置

结构为一维数组,各项参数见注释

return  array(    'theme'     =>      'default',   //主题    'debug'     =>      true,       //是否调试信息    'log_level' =>      'DEBUG',    //日志打印级别EMERGENCY|ALERT|CRITICAL|ERROR|WARNING|NOTICE|INFO|DEBUG    'cache_expire'  =>  3600,       //缓存时间,单位秒    'prefix'  =>  'sobey_',   //存储键值前缀,包含db和cache);

数据库配置

结构为二维数组,默认使用default,可参考default结构配置多个数据库配置如test

return  array(    'default'   =>  array(            'database_type'=>'mysql',            'database_name'=>'ecshop',            'server'=>'127.0.0.1',            'username'=>'root',            'password'=>'123456',            //其他可选参数参见php手册            //http://www.php.net/manual/en/pdo.setattribute.php            'port'=>3306    ),    //test配置非系统默认    'test'      =>  array(        //.........    ),);

Memcached配置

结构为二维数组,默认使用default,可参考default结构配置多个数据库配置如test

return array(    'servers'=>array(        //array('域名','端口','权重')     array('127.0.0.1','11211'),    ),    //options为Memcached::setOptions参数    'options'=>array(        //Memcached::OPT_HASH => Memcached::HASH_MURMUR,        //Memcached::OPT_PREFIX_KEY => "widgets"    ),);

smarty配置

结构为二维数组,默认使用default,可参考default结构配置多个数据库配置如test

return array(    'servers'=>array(        //array('域名','端口','权重')     array('127.0.0.1','11211'),    ),    'options'=>array(        //Memcached::OPT_HASH => Memcached::HASH_MURMUR,        //Memcached::OPT_PREFIX_KEY => "widgets"    ),);

模块modules

一个模块的基本结构为,请遵循以下的规则:
|-src/      代码目录
|   ?|-modules/    模块文件夹
|   ?| ?|-xxxmodules/         模块根目录
|   ?| ?| ?|-api/    接口文件目录
|   ?| ?| ?|-controller/     控制器文件夹 |   ?| ?| ?|-libs/       工具类库
|   ?| ?| ?|-model/     模型类库

项目

开发技巧

Core文件

  • Core::config($file,[$key,[$dafault = false,[$reload = false]]])   获取配置文件

  • Core::load_func($func,[$path= '']) 加载函数

  • Core::log($module,$level,$message,[$context = array()]) 日志记录

  • Core::db([$key='default',[$option=array()]]) 获取db实例

  • Core::memcached([$key='default',[$servers=array(),[$options=array()]]]) 获取memcached实例

项目函数库

一些项目的全局函数位于/src/libs/functions/global.php,该文件会被自动加载。自己可新建模块的函数库并使用Core::load_func()引入使用

模版

模版文件位于: /src/teplate/{风格}/sso(模块)下,为smarty语法文件。

项目主页:http://www.open-open.com/lib/view/home/1429273546408

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn