dmz社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 1700|回复: 2

[php框架] 禅道 Rest API 开发

[复制链接]
  • TA的每日心情
    奋斗
    4 天前
  • 签到天数: 237 天

    [LV.7]常住居民III

    4425

    主题

    1432

    帖子

    9869

    积分

    会|员

    Rank: 9Rank: 9Rank: 9

    积分
    9869
    发表于 2019-6-20 01:01:22 | 显示全部楼层 |阅读模式

    本站资源全部免费,回复即可查看下载地址!

    您需要 登录 才可以下载或查看,没有帐号?立即注册

    x

    所谓老的系统,是指没有使用PHP 5.3以上命名空间(namespace)特性编码的系统。

    但是,只要你的系统运行在 PHP 5.3及以上的环境,在你的老系统中,是可以使用这些基于新特性如命名空间编码的库或代码的。

    以前只是有洁癖不用而已。

    比如,我是个工具控,想让所用的禅道系统也像那些国际化开源 Issue 项目一样有一套标准开放的 API - 禅道本身是有套 html、json 自适配模式可以当接口用的,可以用于其他客户端或系统集成。这几天在尝试编写的用于兼容 Redmine REST 风格接口的禅道 PMS API,就有意识的用了这种混合的写法。

    由于要兼容 Redmine 的 REST 风格,首先选用了 Slim 这个微服务框架,毫无疑问,它是要求运行环境>5.3的,但我总得复用禅道已有的代码,这样效率才高。

    原理很简单,就是一根反斜杠,或者两根。

    先用 composer 初始化了 slim 库。

    重点部位的代码:

    入口文件 index.php

    [PHP] 纯文本查看 复制代码
    require __DIR__ . '/vendor/autoload.php';
    require __DIR__ . '/inc/zentao/nb/Autoloader.php';
    \zentao\nb\Autoloader::register();
    
    $app = \zentao\core\Application::app(dirname(ZTNB_ROOT)); //禅道的router
    
    $slim = new \Slim\Slim();
    
    $routes = require __DIR__ . '/data/config/routes.php';
    
    foreach ($routes as $method => $_routes) {
        if ($_routes) {
            foreach ($_routes as $rule => $map) {
                $slim->$method($rule, '\\zentao\\nb\\resource\\' . $map);
            }
        }
    }
    
    $slim->run();

    \zentao\core\Application 是独立封装的兼容禅道原来运行环境的类,由禅道中的 framework/router.class.php 改造而来,主要用于加载禅道中的相关资源如配置文件、模型等。精华应该在这里面,主要是加了一些“\”来让微服务中能跑起来禅道运来的运行环境,并作为一个命名空间的桥梁可以在新的代码中调用。

    再看看资源类的父类 \zentao\nb\Resource,片段

    [PHP] 纯文本查看 复制代码
    <?php
    
    namespace zentao\nb;
    
    /**
     * 资源类 父类
     */
    class Resource {
    
        public function __construct() {
            
        }
    
        /**
         * Load the model file of one module.
         * 
         * @param   string      $methodName    The method name, if empty, use current module's name.
         * @access  public
         * @return  object|bool If no model file, return false. Else return the model object.
         */
        protected function loadModel($moduleName) {
            $modelFile = \helper::setModelFile($moduleName);
    
            /* If no model file, try load config. */
            if (!\helper::import($modelFile)) {
                $this->app->loadConfig($moduleName, false);
                $this->app->loadLang($moduleName);
                $this->dao = new dao();
                return false;
            }
    
            $modelClass = class_exists('ext' . $moduleName . 'model') ? 'ext' . $moduleName . 'model' : $moduleName . 'model';
            $modelClass = '\\' . $modelClass;
            if (!class_exists($modelClass))
                $this->app->triggerError(" The model $modelClass not found", __FILE__, __LINE__, $exit = true);
    
            $this->$moduleName = new $modelClass();
            $this->dao = $this->$moduleName->dao;
            return $this->$moduleName;
        }

    这样可以在资源类中调用禅道的 model 类。

    还有另外一种用法,加载语言包:

    [PHP] 纯文本查看 复制代码
    <?php
    
    namespace zentao\nb\resource;
    
    use zentao\nb\enum\BugType;
    
    /**
     * 项目自行定义的问题分类
     */
    class IssueCategory extends \zentao\nb\resource {
        
        public function fetchAll($format = 'json') {
            global $app;
    
            $types = $app->loadLang('bug')->bug->typeList;
            $issue_categories = array();
            foreach ($types as $key => $name) {
                
                $issue_categories[] = array('id' => BugType::getIdByInterId($key), 'name' => $name);
            }
            
            echo json_encode(array('issue_categories' => $issue_categories));
        }
        
        /**
         *   根据项目来取其中定义的分类
         * @param int $projectId
         * @param string $format
         */
        public function fetchAllByProjectId($projectId, $format = 'json') {
            $model = $this->loadModel('project');
            $project = $model->getById($projectId);//TODO 支持按项目代号查找
            if (!$project) {
                $this->responseNotExixted();
            }
            
            global $app;
            $types = $app->loadLang('bug')->bug->typeList;
            $issue_categories = array();
            foreach ($types as $key => $name) {
                
                $issue_categories[] = array('id' => BugType::getIdByInterId($key), 'project' => array('id' => $projectId, 'name' => $project->name), 'name' => $name);
            }
            
            echo json_encode(array(
                'issue_categories' => $issue_categories,
                'total_count' => 2
            ));
        }
    }

    基本项目结构如下:

    5409-20151202113043515-30319840.png

    代码:https://github.com/web3d/zentao-rest-api

    项目只是初步成型,尚未完成。

    5409-20151202114537343-1356995417.png

    这是在 NB 中的任务列表。

    5409-20151202114545546-1877111206.png

    这是在 NB 中的任务详情


    回复

    使用道具 举报

    该用户从未签到

    23

    主题

    8155

    帖子

    1052

    积分

    荣誉会员

    积分
    1052

    发表于 2019-6-22 17:03:34 | 显示全部楼层
    好好 学习了 确实不错

    该用户从未签到

    3

    主题

    7704

    帖子

    1025

    积分

    技冠群雄

    Rank: 6Rank: 6

    积分
    1025

    发表于 2019-6-24 07:37:21 | 显示全部楼层
    找到好贴不容易,我顶你了,谢了
    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|Archiver|小黑屋|本站代理|dmz社区

    GMT+8, 2024-4-27 07:16 , Processed in 0.100510 second(s), 38 queries .

    Powered by Discuz! X3.4 Licensed

    Copyright © 2001-2021, Tencent Cloud.

    快速回复 返回顶部 返回列表