Discuz!NT 扩展之空间、相册、交易插件

Discuz!NT 扩展之空间、相册、交易插件

Discuz!NT 对系统的扩展性提供了很好的支持,第三方开发者可以基于Discuz!NT扩展点开发很多插件,来改善或者扩展系统的功能。那么Discuz!NT 扩展点都体现在哪些地方呢?是如何来实现这些扩展点,让它在主系统上能够很好的插拔呢?

先来一张Discuz!NT的插件系统类图吧!(根据自己理解画的)

构建插件系统,主要是为了让插件能够在主系统上进行很好的插拔。主系统通过调用SpacePluginProviderAlbumPluginProviderMallPluginProvider来与插件进行交互(因为在这些PluginProvider中利用反射创建插件实例,所以主系统完全可以通过PluginProvider使用插件提供的功能)。

可以查看SpacePluginProvider的源码:

第三方开发者开发的插件需要实现SpacePluginBaseAlbumPluginBaseMallPluginBase这些抽象类的方法。下面是通过Reflector看到的SpacePlugin源码:

插件开发好了后,又是怎样将它插入主系统的呢?还是以空间插件为例,从网上下载了空间插件后,只需要做以下几步:

复制下列目录到 Discuz!NT 论坛目录 覆盖同名目录

  bin

  admin

  config

  install

  javascript

  templates  

  space

运行 http://您的域名/bbs/install/pluginsetup.aspx 按照提示进行操作即可。

在后台模板管理中重新生成模板。

4 Discuz!NT 3.5.1版本之前在 后台 全局 基本设置 里开启模块。

  Discuz!NT 3.5.2版本在 后台 全局 常规选项 站点信息 里开启模块

通过查看PluginSetup.aspx.cs的源码:

可以发现在安装过程中,需要更改数据库,导入插件菜单

更改数据库只需执行脚本就可以完成,导入插件菜单这儿就简单的说一下原理:

在后台管理系统中的导航菜单都是通过navmenu.config文件存储的:

导入插件菜单首先就得更改navmenu.config文件。

然后再根据navmenu.config生成json数据:

通过navmenu.js存储:

在后台页面中通过javascript访问navmenu.js对导航控件进行数据绑定。

到这儿,空间插件就很好的插入到主系统了。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Discuz! 是一款流行的论坛系统,支持插件开发,以下是一个简单的插件开发实例: 1. 创建插件目录 在 Discuz! 的 plugin 目录下创建一个新的目录,例如 myplugin。 2. 创建插件文件 在 myplugin 目录下创建一个新的文件,例如 myplugin.inc.php。这个文件是插件的主文件,需要包含以下代码: ``` <?php if(!defined('IN_DISCUZ')) { exit('Access Denied'); } class plugin_myplugin { // 插件代码 } ?> ``` 3. 注册插件 在 myplugin.inc.php 文件中,使用以下代码注册插件: ``` <?php if(!defined('IN_DISCUZ')) { exit('Access Denied'); } class plugin_myplugin { function __construct() { // 注册插件 global $_G; $_G['cache']['plugin']['myplugin'] = array( 'name' => '我的插件', 'version' => '1.0', 'description' => '这是我的第一个 Discuz! 插件', 'author' => '我的名字', 'pluginurl' => '', 'url' => '', 'lang' => '', 'modules' => array() ); } } ?> ``` 4. 实现插件功能 在插件的主文件中,实现插件的功能。例如,在 myplugin.inc.php 文件中加入以下代码: ``` <?php if(!defined('IN_DISCUZ')) { exit('Access Denied'); } class plugin_myplugin { function __construct() { // 注册插件 global $_G; $_G['cache']['plugin']['myplugin'] = array( 'name' => '我的插件', 'version' => '1.0', 'description' => '这是我的第一个 Discuz! 插件', 'author' => '我的名字', 'pluginurl' => '', 'url' => '', 'lang' => '', 'modules' => array() ); } function global_footer() { // 在页面底部添加一段文本 echo '<div>这是我的第一个 Discuz! 插件</div>'; } } ?> ``` 这段代码将在页面底部添加一段文本,展示插件的功能。 5. 安装插件 将 myplugin 目录上传到 Discuz! 的 plugin 目录下,然后在后台插件管理页面中安装插件即可。 这是一个简单的 Discuz! 插件开发实例,你可以根据自己的需求,实现不同的插件功能。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值