Joomla自身并不直接支持Composer,但我们可以通过将其“封装”进Joomla扩展库来方便地使用第三方PHP库。这种方法尤其适用于大型项目,确保代码经过充分测试,并在生产环境中稳定运行。 创建扩展包后,即可在任何需要的地方安装它。 当库有新版本发布时,更新封装后的扩展即可,享受Joomla扩展的标准更新机制,包括通过CLI进行更新。更新前,务必在管理后台查看扩展的变更日志。 
Joomla、PSR和Symfony的兼容性
Joomla遵循PSR标准,因此使用起来非常方便。Joomla核心包含一些Symfony组件(Console, String, VarDumper, YAML, ErrorHandler等),这意味着添加更多Symfony组件将会非常容易集成。 除了这些组件,Joomla自身也提供许多有价值的功能。 如何在Joomla扩展中封装第三方PHP库? 方法很简单。通常,库文件位于src文件夹中。在该文件夹旁边,根据Joomla文档(manual.joomla.org)创建Joomla扩展的XML清单文件。最后,将所有内容打包成zip压缩文件即可安装。 如果库需要数据库表,则需在安装或更新过程中使用SQL查询添加必要的表结构。由于Joomla 4使用命名空间,在扩展的XML清单中指定命名空间至关重要。以下是一个简化的Joomla库XML清单示例: 1 2 3 4 5 6 7 8 9 10 11 12 | <?xml version= "1.0" encoding= "utf-8" ?>
<extension method= "upgrade" type= "library" >
<name>webtolk amocrm library</name>
<libraryname>webtolk/amocrm</libraryname>
<version>1.2.1</version>
...
< namespace path= "src" >webtolkmocrm</ namespace >
<files>
<folder>src</folder>
<filename>amocrm.xml</filename>
</files>
</extension>
|
标签指定src文件夹将被复制到jpath_site/libraries/webtolk/amocrm。部分指定需要从压缩包中提取的文件。webtolkmocrm指定为jpath_site/libraries/webtolk/amocrm下的src文件夹注册命名空间webtolkmocrm。 重要注意事项: - Joomla 4.2.7之前的版本,XML清单中的标签无效。 需要添加一个系统插件,在onafterinitialize事件中使用jloader类注册命名空间。因此,需要同时打包库和插件。从Joomla 4.2.7开始,此问题已修复,无需再使用插件。
- 目前,更新库等同于重新安装。 这意味着需要删除并重新安装扩展。这是Joomla 3.x版本遗留的问题。 这很重要,因为安装任何扩展都会在#__extensions表中创建一个条目。 如果库需要存储参数到数据库,则需要在安装和更新过程中都处理这些参数。
以下代码片段展示了如何在安装/更新过程中处理数据库参数: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 | <?php
use JoomlaCMSHelperLibraryHelper;
use JoomlaCMSCacheCache;
public function preflight(string $type , InstallerAdapter $adapter ): bool
{
if ( $type == 'uninstall' ) {
return true;
}
if ( $type == 'update' ) {
$lib_params = LibraryHelper::getParams( 'webtolk/amocrm' );
$jconfig = $this ->app->getConfig();
$options = array (
'defaultgroup' => 'wt_amo_crm_temp' ,
'caching' => true,
'cachebase' => $jconfig ->get( 'cache_path' ),
'storage' => $jconfig ->get( 'cache_handler' ),
);
$cache = Cache::getInstance( '' , $options );
$cache ->store( $lib_params , 'wt_amo_crm_temp' );
}
return true;
}
|
在postflight()方法中,使用LibraryHelper::saveParams('webtolk/amocrm', $lib_params);将保存的参数恢复。 - 必须在扩展管理器中启用库(菜单 - 系统 - 管理 - 扩展)。
- 库通常需要参数(API密钥、令牌等),这些参数需要由Joomla管理后台人员指定。 为此,编写一个插件会比较方便(库扩展类型没有自己的参数配置界面)。可以使用系统组或自定义组。 可以在库中这样获取插件参数:
1 2 3 4 5 6 7 8 9 10 11 12 | <?php
use JoomlaCMSPluginPluginHelper;
use JoomlaRegistryRegistry;
if (PluginHelper::isEnabled( 'system' , 'wt_amocrm' )) {
$plugin = PluginHelper::getPlugin( 'system' , 'wt_amocrm' );
$params = json_decode( $plugin ->params);
$param = $params ->param;
$params = new Registry( $plugin ->params);
$param = $params ->get( 'param' , '默认值' );
}
|
Joomla社区资源: 希望以上信息对您有所帮助。 |