从无到有,使用Phalcon多模块作接口开发模板

前提:phalcon-devtools工具

创建基本框架

创建一个多模块的项目

phalcon project website modules

创建新module

1.新增加一个名叫backend,以Test\Modules为命名空间的后台模块

phalcon module –-name backend –-namespace=Test\Modules –output=app/modules

2.使用phalcon devtools生成一个带继承的新控制器

phalcon controller –-name index -output=app/modules/backend/controllers –base-class=ControllerBase

这里用到了phalcon controller的三个参数:–name参数指定控制器的名称,–output参数指定生成控制器的位置,–base-class参数指定继承的基类。

使用

  1. 要想使用新的模块中的新方法,还需要在配置文件中进行一些修改:
      bootstrap_web.php中注册模块
'backend'  => ['className' => 'Test\Modules\Backend\Module'],

  loader.php中注册模块类

'Test\Modules\Backend\Module'  => APP_PATH . '/modules/backend/Module.php',

2.如果要使用公共的model则需要在相应模块下注册命名空间
fontend模块下Module.php中

$loader->registerNamespaces([
    'Test\Modules\Frontend\Controllers' => __DIR__ . '/controllers/',
    'Test\Modules\Frontend\Models' => __DIR__ . '/models/',
    'Test\Common\Models'    =>  APP_PATH . '/common/models' //添加公共model
]);

接口开发常用功能

1.开启logger
  config.php配置logger路径

'logger'    =>  [
    'backend'  =>  APP_PATH . '/../logs/backend/log.txt',
    'frontend' =>  APP_PATH . '/../logs/frontend/log.txt'
],

  各个模块Module.php中注入logger单例到di

$di->setShared('logger' , function () use ($di) {
    $config =   $di->getConfig();
    $logger =   new FileAdapter($config->logger->backend);

    //  less or equal than DEBUG will be logged
    $logger->setLogLevel(\Phalcon\Logger::DEBUG);

    return $logger;
});

  基类中添加saveLog方法

public function saveLog($msg){
    $logger =   $this->di->get('logger');
    $logger->log($msg,\Phalcon\Logger::DEBUG);
}

  基类中添加saveDBFailedLog方法

public function saveDBFailedLog($model){
    $logger =   $this->di->get('logger');
    $msg    =   'Failed to save db at '.$model->getSource();
    foreach($model->getMessages() as $message){
        $msg .= "\n" . $message;
    }
    $logger->log($msg,\Phalcon\Logger::DEBUG);
}

2.作为接口,返回json
在base类中添加方法

public function getResponse($resArray){
    $response   =   $this->response;

    $response->setHeader("Access-Control-Allow-Origin","*");
    $response->setHeader("Access-Control-Allow-Methods", "GET, POST, PATCH, PUT, OPTIONS");
    $response->setHeader("Access-Control-Allow-Headers", "x-requested-with,content-type");

    $feed   =   json_encode($resArray);
    $response->setContent($feed);

    return $response;
}

附录:一个完整的模板

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

hober.z

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值