Home  >  Q&A  >  body text

php - 多插件调用同一接口的先后问题

写的程序的插件系统发现有好几个插件调用了同一个接口,我想知道如何解决先后执行的问题。比如说我有如下的场景:

A插件和B插件都调用了xxoo接口,A插件用来在这个接口生成东西的,B插件是来统计整个页面的运行时间的。

实际使用上B在A前面就执行了,这样就有问题了。因为插件系统设置的是直接遍历所有的插件,如果有这个钩子函数的话就执行,所以没办法绝对控制A和B的执行顺序。

我想问一下如何(改进我的插件系统)才能达到我的效果?

PHP中文网PHP中文网2749 days ago477

reply all(3)I'll reply

  • 巴扎黑

    巴扎黑2017-04-10 14:56:13

    半夜睡不着了,答个题玩玩儿。


    插件之间不应该耦合。

    既然是插件,那么A就不应该知道B的存在,反之依然。

    那么,A调用系统接口的时候,他不知道还有多少个插件也要调用此接口,也许是在他之前,也许是在他以后,也许是和他同时。

    如果你是插件开发者,就应该考虑这方面的问题,不能因为系统安装了你的插件导致其他的好多插件不能正常工作了。

    但是插件之间相互调用,相互影响的情况也有,比如 jq 的幻灯片插件就需要使用到动画功能,php 的
    验证码模块就依赖于 gd 库。因此,可以在插件的配置文件中写明此插件的依赖关系。

    假设 A 依赖于 B,放系统在加载 A 时,B 没有加载的话,系统会去加载 B,然后再加载 B。

    至于顺序和优先级,我觉得没有必要。只要搞好依赖关系就行。

    reply
    0
  • PHP中文网

    PHP中文网2017-04-10 14:56:13

    要看插件之间的耦合度 一个插件和多个插件有关 最好合并成一个
    如果与所有插件有关的逻辑 最好放到系统里而不是插件形式

    reply
    0
  • 黄舟

    黄舟2017-04-10 14:56:13

    按名字的字典序,或者注册顺序(如果插件需要通过某种方式「注册」的话),或者添加一个优先级字段。

    或者更复杂一些,插件可以指定它在哪些插件之前或者之后执行。

    reply
    0
  • Cancelreply