问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

如何简单的理解php对接的接口?

发布网友 发布时间:2022-04-06 02:52

我来回答

2个回答

懂视网 时间:2022-04-06 07:14

推荐:《PHP视频教程》

在对接第三方接口的时候,总是会看到接口后缀会带着v1,v2这样的标识,我们知道这些都是接口版本的概念,那么如果我方需要提供对外的接口,或者对接web端和APP端的时候,希望公用同一个接口,但是接口所渲染的数据表现形式不太一致,以及接口授权也不太一致的情况下,如何做到使用不同版本,且不同版本直接互不影响且同时共存呢?

首先笔者在考虑到接口设计时,有几大模块:

  • 控制器层(controller):笔者将其定义为入口层(相当于java的dao层)

  • 服务层(services):逻辑服务层,控制器入口层通过版本号标识转接到不同的服务层,具体的代码逻辑实现都在此处编写

  • 行为层(behavior):也可理解为事件层,服务中间件,行为钩子都将在此处控制,入口权限过滤校验,对接第三方服务扩展通过行为钩子抽出,不让其加大服务层的代码臃肿

  • 模型层(model):该层根据实际业务和开发习惯而定,可要可不要

  • 校验层(validate):笔者认为很有必要,所有独立拉出一个目录来做相关校验,不管是独立校验,校验引擎,还是框架自带校验都在该目录定义,方便维护和扩展

  • 公共层(common):系统公共代码,比如附件上传,下载等

  • 配置层(config):内部配置,根据需求自定义是否需要

  • 语言包(lang):根据需求而定

  • 复用层(tarits):根据实际需求而定

  • 任务层(job):根据实际需求而定

  • 目录层级如图所示:

    那么在入口层如何转接到服务层呢?因为在这过程我们会将接口中的版本号转接到不同的版本服务层。
    首先在控制器入口层写一个基类控制器,后续所有的控制器都将会继承该类,在构造函数中调取行为类中的解析服务层代码,将服务层类初始化给基类变量!

     public $service = null;
    
     /**
     * 构造函数处理头部请求
     *
     * @return void
     */
     public function __construct($type = 0, Request $request)
     {
     // 登录跳过
     if (!$type) {
      // 注册行为监听
      Hook::add('app_init', [
      // 校验请求接口的身份(身份验证)
      'appsaasehaviorAuthToken'
      ]);
      Hook::listen('app_init', []);
     }
     // 立即执行初始化控制器服务应用
     $this->service = Hook::exec('appsaasehaviorInitializtionService', ['tag' => $type, 'request' => $request]);
     }

    服务InitializtionService解析路由,判断,将服务层实例化

     public function run($params)
     {
     // 兼容控制器分层,优化控制器目录结构
     $controller = request()->controller();
     $controllerArray = explode('.', $controller);
     $controllerLength = count($controllerArray);
     $appendControllerName = '';
     if ($controllerLength == 1) {
      $appendControllerName = $controllerArray[0];
     } else {
      for ($i = 0; $i < $controllerLength - 1; $i++) {
      $appendControllerName .= strtolower($controllerArray[$i]) . '';
      }
      $appendControllerName .= ucfirst($controllerArray[($controllerLength - 1)]);
     }
    
     // $controller = 'appsaascontroller' . request()->controller();
     $controller = 'appsaascontroller' . $appendControllerName;
     $verion = request()->param('version');
     $init_service = function () use ($controller, $verion, $params) {
      // dump($controller);
      // $controller = 'appsaascontroller	estTest';
      $reflection = new ReflectionClass($controller);
    
      if (property_exists($controller, 'versions')
      && isset($reflection->getStaticProperties()['versions'][$verion])
      ) {
      // 默认规则返回,在前在后不允许返回其他信息
      $service = $reflection->getStaticProperties()['versions'][$verion];
      // 判断控制器服务文件是否存在
      return class_exists($service) ? new $service($params['tag'], $params['request']) : Merror::getInstance()->jsonApi(40006);
      } else {
      Merror::getInstance()->jsonApi(40001);
      }
     };
    
     return is_null($verion) ? Merror::getInstance()->jsonApi(40002) : $init_service();
     }

    这样在控制器中文件定义如下调用服务层逻辑代码,而不用关心是属于哪个服务层类,服务层代码只和版本有关

     class Sysorder extends Saas
     {
     /**
     * 版本服务调度属性--必须默认一个且是v1
     *
     * @var array
     */
     protected static $versions = [
     'v1' => appsaasservicessyscenterSysorder::class,
     ];
    
     /**
     * 获取信息集权限目录
     *
     * @method POST|GET
     * @name getSubMenuListCate
     */
     public function getSubMenuListCate()
     {
     return json($this->service->getSubMenuListCate());
     }
    
     /**
     * 获取列表
     *
     * @method POST|GET
     * @name getSysOrderList
     */
     public function getSysOrderList()
     {
     return json($this->service->getSysOrderList());
     }

    结语:此设计抛砖引玉,具体实现看各位phper大显神通了!
    api多版本接口设计模式,可以参考(基于ThinkPhp5.1实现,框架不同,设计理念一致):www.kancloud.cn/lijianlin/ethantp5...
    最后推广一下笔者自研的一套基于laravel设计的工作流流程引擎(https://learnku.com/laravel/t/48967),欢迎研究自研!

    注:我这个设计主要是为了多版本接口开发的一种设计而已,每个人都有自己的开发习惯,不予强制,只是以便代码的维护和阅读!仅此建议而已

    热心网友 时间:2022-04-06 04:22

    固定了输出或者发送请求的格式,这个做一个接口就明白了,什么支付接口什么的
    声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
    在公交车上实施扒窃,会受到怎样的处罚? 交通违法行为识别 公交车扒窃会如何处罚? 郑州鱼缸清洗找哪家公司做得比较好? 郑州有没有专业维修鱼缸,清洗鱼缸的? ...的鱼缸,放在办公室养些鱼水草之类的。郑州哪里有卖这样的鱼缸。_百... 我们公司想要定做个观赏鱼缸,不知道郑州哪家公司最专业? 谁知道郑州生态鱼缸定做哪家做的效果最好? 联想电脑启用无线功能的功能键? 笔记本电脑怎么连接网笔记本电脑怎样连接无线网 php版本控制是什么 怎么样判断php扩展与php版本的兼容性 ectouch微商城如何兼容多高版本php hibernate中设置constrained的问题 蓝屏代码0xc0000098 win7开机时出现0xc0000098这个代码是怎么回事?和内存条有关吗?如何解决? 电脑出现0xc0000098,用老毛桃无法修复 0xc0000098是哪里的问题,怎样快速解决? 电脑启动显示恢复错误代码:0xc000098 电脑windows出现这个0xc0000098怎么办? 请求帮助,本人笔记本开不了机,启动显示状态0xc0000098,没有U盘没有光 电脑开不了机,显示oxc0000098,请问如何修复,电脑里还有有用文件, 电脑这种情况怎么处理0xc0000098 电脑出现代码0xc0000098怎么办 重装系统出现0xc0000098怎么解决? 电脑开机0xc0000098不用U盘怎么处理? 0xc00000098不能开机 重装系统出现0xc0000098怎么解决 电脑开不了机显示状态0xc0000098怎么办呢各位大神? 打开ug8.0时出现无法正常启动0xc000007b是什么原因? PHP版本控制 是怎么玩的 PHP如何保证api接口数 PHP的预定义接口都有哪些,都是这么使用的? PHP能不能给一个API接口同时发送多条请求! 做个企业网站,必须要必备的几个要素是什么? 建立一个企业网站需要花多少钱? 一个企业网站,都需要具备那些功能? 企业网站为什么要需求分析? 企业网站建设需要考虑的需求? 网站建设公司的具体需求是什么? 建一个企业网站需要做些什么? 企业网站有哪些要求? 企业网站都需要做什么? 什么是命名空间 如何理解命名空间?使用命名空间有什么好处? C#里的命名空间是什么意思? 1】 命名空间里可以包容 命名空间? 2】 类一定在 命名空间里面; 3】 命名空间里面 可以 声明变量? c#中什么叫做命名空间? C++命名空间到底有什么作用?请举例说明 学校学了一个月C语言,然后开始学c#,感觉对c#的命名空间和类表示不能理解,有通俗一点的解释吗