PhalApi框架使用笔记

什么是PhapApi

PhalApi是一个PHP轻量级开源接口框架,致力于快速开发接口服务。 支持HTTP/SOAP/RPC等协议,可用于搭建接口/微服务/RESTful接口/Web Services,

.

├── PhalApi //PhalApi框架,后期可以整包升级

├── Public //对外访问目录,建议隐藏PHP实现

│ └── demo //Demo服务访问入口

├── Config //项目接口公共配置,主要有:app.php, sys.php, dbs.php

├── Data //项目接口公共数据

├── Language //项目接口公共翻译

├── Runtime //项目接口运行文件目录,用于存放日记,可软链到别的区

└── Demo //应用接口服务,名称自取,可多组

├── Api //接口响应层

├── Domain //接口领域层

├── Model //接口持久层

└── Tests //接口单元测试

PhalApi核心思想

核心思想:DI依赖注入

PhalApi框架三层结构Api+Domain+Model模式

1.1 Api层

它会通过控制器把请求转发到service层作处理,并将处理结果在页面展示,所以Api更像担当控制器(C)的作用。

1.2 Domain层

Domain层主要负责的是具体的业务实现,如数据获取,一个Domain方法就是一个小的业务具体实现(注意尽量把业务划分得细一点方便通用)

1.3 Model层

数据库操作单独提炼出来统一处理

PhalApi通用公共函数和 拦截器过滤器

公用函数和拦截器

1 公共函数

首先在我们的根目录建立一个文件夹叫做general通用的意思,里面分别有两个文件夹Common(受TP的影响)和Intercept两个文件,我们在里面放入我们自己的文件,当然需要按照正确的规则比如Common_Base等

然后我们要使用的话当然要注册我们这个general文件作为自带加载文件,然后注册自己需要用的类,如下在入口文件index.php进行注入

/** ---------------- 通用方法加载 ---------------- **/

//加载项目通用文件

DI()->loader->addDirs('General');

//通用函数基础类

DI()->base = new Common_Base();

2 拦截器

PhalApi已经有自带的拦截器,使用时一样需要先注入

PhalApi结构

加入我们需要对token进行校验,一些方法是需要验证,有些方法又是不需要验证 token.我们需要怎么实现呢?

可以在项目目录 Config/app.php进行定义一个数组,数组包括的是需要验证token的类方法名

/**

* 需要带Token的接口

*/

apiTokenRules' => array(

'User.info',

'User.updateInfo',

)

我们定义好相关需要校验token的数组,在 Filter下面的 SimpleToken 来进行校验,所有的接口访问都会走改注册了的token校验方法,我们就需要在校验方法里面做过滤拦截,

public function check() {

$service = DI()->request->get('service');

$app=DI()->config->get('app');

$app = json_decode(json_encode($app),true);

$apiTokenRules = $app['apiTokenRules'];

if (in_array($service,$apiTokenRules)) {

$allParams = DI()->request->getAll();

$token = isset($allParams['token']) ? $allParams['token'] : '';

$user_id = $allParams['user_id'];

if (empty($user_id)){

throw new PhalApi_Exception_BadRequest('缺少必要参数user_id');

}

$service_token = DI()->cache->get($user_id.'token');

if (empty($service_token)){

throw new PhalApi_Exception_BadRequest('请重新登录',99);

}else{

if (strcmp($token,$service_token) !== 0){

DI()->logger->debug('Wrong Token', array('needToken' => $service_token));

throw new PhalApi_Exception_BadRequest('Token错误,请重新登录',99);

}else{

DI()->cache->set($user_id.'token',$service_token,24*60*60);

}

}

}

}

PhalApi 第三方SDK使用集成方法

参考大神的OSC@GIT仓库 https://github.com/phalapi/phalapi-library ,仓库有比较多的SDK包 供下载使用 git clone https://github.com/phalapi/phalapi-library.git

以短信SMS 容联云短信服务器拓展为例

配置方式非常简单只需要把拓展下载下来放入Library文件内即可,然后就可以使用如下方法进行实例,文件名称以Lite.php 为准,再到根目录进行注入使用,

DI()->sms= new SMS_Lite();

项目中添加Common模块

Common目录下是放置一些公共类,这里只是作为一个通常的划分目录,如签名类,这里没有过多的规范,可以这么理解,小的公共类放到Common;若是大的公共库或依赖于第三方SDK的,可以封装到扩展类库中

image.png

使用的时候

DI()->functions = new Common_Functions();

// DI()->functions ="Common_Functions";

$res= DI()->functions->HttpGet($url);

Logo

开放原子开发者工作坊旨在鼓励更多人参与开源活动,与志同道合的开发者们相互交流开发经验、分享开发心得、获取前沿技术趋势。工作坊有多种形式的开发者活动,如meetup、训练营等,主打技术交流,干货满满,真诚地邀请各位开发者共同参与!

更多推荐