在 Joomla 中连接第三方 PHP 库
时间:2024-12-27 19:58:03 460浏览 收藏
小伙伴们有没有觉得学习文章很有意思?有意思就对了!今天就给大家带来《在 Joomla 中连接第三方 PHP 库》,以下内容将会涉及到,若是在学习中对其中部分知识点有疑问,或许看了本文就能帮到你!
巧用Joomla扩展轻松集成第三方PHP库
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清单示例:
<?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">webtolk\amocrm</namespace>
<files>
<folder>src</folder>
<filename>amocrm.xml</filename>
</files>
</extension>
<libraryname>
标签指定src
文件夹将被复制到jpath_site/libraries/webtolk/amocrm
。<files>
部分指定需要从压缩包中提取的文件。<namespace path="src">webtolk\amocrm</namespace>
指定为jpath_site/libraries/webtolk/amocrm
下的src
文件夹注册命名空间webtolk\amocrm
。
重要注意事项:
- Joomla 4.2.7之前的版本,XML清单中的
<namespace>
标签无效。 需要添加一个系统插件,在onafterinitialize
事件中使用jloader
类注册命名空间。因此,需要同时打包库和插件。从Joomla 4.2.7开始,此问题已修复,无需再使用插件。 - 目前,更新库等同于重新安装。 这意味着需要删除并重新安装扩展。这是Joomla 3.x版本遗留的问题。 这很重要,因为安装任何扩展都会在
#__extensions
表中创建一个条目。 如果库需要存储参数到数据库,则需要在安装和更新过程中都处理这些参数。
以下代码片段展示了如何在安装/更新过程中处理数据库参数:
<?php
use Joomla\CMS\Helper\LibraryHelper;
use Joomla\CMS\Cache\Cache;
/**
* 在扩展安装/更新/卸载过程开始前调用的函数。
*
* @param string $type 更改类型 (install, discover_install, update, uninstall)
* @param InstallerAdapter $adapter 调用此方法的适配器
*
* @return boolean 成功返回true
*
* @since 1.0.0
*/
public function preflight(string $type, InstallerAdapter $adapter): bool
{
if ($type == 'uninstall') {
return true;
}
/**
* Joomla更新库类型扩展时,会删除扩展(以及数据库中的数据),然后重新安装。
* 为避免丢失数据库中的库数据,我们编写了这段代码。
*
* @see https://github.com/joomla/joomla-cms/issues/39360
*
*/
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管理后台人员指定。 为此,编写一个插件会比较方便(库扩展类型没有自己的参数配置界面)。可以使用系统组或自定义组。 可以在库中这样获取插件参数:
<?php
use Joomla\CMS\Plugin\PluginHelper;
use Joomla\Registry\Registry;
if (PluginHelper::isEnabled('system', 'wt_amocrm')) {
$plugin = PluginHelper::getPlugin('system', 'wt_amocrm');
$params = \json_decode($plugin->params);
$param = $params->param;
// 或者使用 Joomla\Registry\Registry
$params = new Registry($plugin->params);
$param = $params->get('param', '默认值');
}
Joomla社区资源:
- https://joomla.org/
- Joomla社区Mattermost聊天室
- webtolk Joomla扩展
- (俄文文章链接)
希望以上信息对您有所帮助。
今天关于《在 Joomla 中连接第三方 PHP 库》的内容介绍就到此结束,如果有什么疑问或者建议,可以在golang学习网公众号下多多回复交流;文中若有不正之处,也希望回复留言以告知!
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
162 收藏
-
391 收藏
-
188 收藏
-
210 收藏
-
414 收藏
-
426 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 507次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 484次学习