欢迎来到福编程网,本站提供各种互联网专业知识!

如何在旧的PHP系统中使用PHP 5.3之后的库

发布时间:2015-12-02 作者:x3d 来源:转载
这篇文章主要介绍了如何在旧的PHP系统中使用PHP5.3之后的库,需要的朋友可以参考下

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

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

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

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

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

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

先用composer 初始化了slim 库。

重点部位的代码:

入口文件 index.php

代码
  1. require __DIR__ . '/vendor/autoload.php';
  2. require __DIR__ . '/inc/zentao/nb/Autoloader.php';
  3. zentaonbAutoloader::register();
  4. $app = zentaocoreApplication::app(dirname(ZTNB_ROOT)); //禅道的router
  5. $slim = new SlimSlim();
  6. $routes = require __DIR__ . '/data/config/routes.php';
  7. foreach ($routes as $method => $_routes) {
  8. if ($_routes) {
  9. foreach ($_routes as $rule => $map) {
  10. $slim->$method($rule, 'zentaonbresource' . $map);
  11. }
  12. }
  13. }
  14. $slim->run();

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

再看看资源类的父类 zentaonbResource,片段

代码
  1. <?php
  2. namespace zentaonb;
  3. /**
  4. * 资源类 父类
  5. */
  6. class Resource {
  7. public function __construct() {
  8. }
  9. /**
  10. * Load the model file of one module.
  11. *
  12. * @param string $methodName The method name, if empty, use current module's name.
  13. * @access public
  14. * @return object|bool If no model file, return false. Else return the model object.
  15. */
  16. protected function loadModel($moduleName) {
  17. $modelFile = helper::setModelFile($moduleName);
  18. /* If no model file, try load config. */
  19. if (!helper::import($modelFile)) {
  20. $this->app->loadConfig($moduleName, false);
  21. $this->app->loadLang($moduleName);
  22. $this->dao = new dao();
  23. return false;
  24. }
  25. $modelClass = class_exists('ext' . $moduleName . 'model') ? 'ext' . $moduleName . 'model' : $moduleName . 'model';
  26. $modelClass = '' . $modelClass;
  27. if (!class_exists($modelClass))
  28. $this->app->triggerError(" The model $modelClass not found", __FILE__, __LINE__, $exit = true);
  29. $this->$moduleName = new $modelClass();
  30. $this->dao = $this->$moduleName->dao;
  31. return $this->$moduleName;
  32. }

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

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

代码
  1. <?php
  2. namespace zentaonbresource;
  3. use zentaonbenumBugType;
  4. /**
  5. * 项目自行定义的问题分类
  6. */
  7. class IssueCategory extends zentaonbresource {
  8. public function fetchAll($format = 'json') {
  9. global $app;
  10. $types = $app->loadLang('bug')->bug->typeList;
  11. $issue_categories = array();
  12. foreach ($types as $key => $name) {
  13. $issue_categories[] = array('id' => BugType::getIdByInterId($key), 'name' => $name);
  14. }
  15. echo json_encode(array('issue_categories' => $issue_categories));
  16. }
  17. /**
  18. * 根据项目来取其中定义的分类
  19. * @param int $projectId
  20. * @param string $format
  21. */
  22. public function fetchAllByProjectId($projectId, $format = 'json') {
  23. $model = $this->loadModel('project');
  24. $project = $model->getById($projectId);//TODO 支持按项目代号查找
  25. if (!$project) {
  26. $this->responseNotExixted();
  27. }
  28. global $app;
  29. $types = $app->loadLang('bug')->bug->typeList;
  30. $issue_categories = array();
  31. foreach ($types as $key => $name) {
  32. $issue_categories[] = array('id' => BugType::getIdByInterId($key), 'project' => array('id' => $projectId, 'name' => $project->name), 'name' => $name);
  33. }
  34. echo json_encode(array(
  35. 'issue_categories' => $issue_categories,
  36. 'total_count' => 2
  37. ));
  38. }
  39. }

基本项目结构如下:

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

这是在 NB 中的任务列表。

这是在 NB 中的任务详情。

以上就是告诉大家如何在旧的PHP系统中使用PHP 5.3之后的库,希望对大家的学习有所帮助。

相关推荐