Discuz!X 插件制作教程 ------ 发布插件

来源:互联网 发布:标致雪铁龙 知乎 编辑:程序博客网 时间:2024/04/30 11:25
我终于写出了自己的一个伟大的插件,我希望别人也能使用这个插件!我想发布这个插件,我该如何做呢?    面对问题
    然而我们刚刚写完了一个插件,但是我们所要面临的问题才刚刚开始,我们需要考虑的内容很多,这些内容包括:
    1. 我使用的语言编码方式是UTF8,我希望那些使用GBK的站长也能使用我的插件
    2. 我可能会使用到数据库来建立我需要使用的表,我该如何建立
    3. 我怎么描述出我的使用条例或者安装条例
    4. 我怎么为我的插件进行插件描述
    5. 我的插件发布在哪里,是否需要收费
    天啊,我头都大了!我根本没有想过这个问题!如此多的问题迎面而来,我该如何解决?嘿嘿,这个时候就是体现我自己价值的时刻了,我们来慢慢的讲解吧!
    语言编码

    要解决语言编码的问题比较的麻烦,首先我们要确保我们所有程序里面没有出现中文字符,其次我们需要新建一个文件:data/plugindata/mtest.lang.php这个文件,写入内容为:

[php] view plaincopyprint?
  1. <?php  
  2. $scriptlang['mtest'] = array(  
  3.         'enable' => '启用',  
  4. );  
  5. $templatelang['mtest'] = array(  
  6. );  
  7. ?>  

然后,在你自己的程序使用前,使用:

[php] view plaincopyprint?
  1. $mlang=$scriptlang['mtest'];  

来调用一下,这样,$mlang这个数组里存放的就是你要使用的内容了。
    接下来,我们要做不同的对应的语言编码的xml文件了。
 
    我相信你一定看到导出这个按钮了,然后就是一个XML文件,把它存放到你的插件目录下面,如果您不愿意做多语言编码的插件,那么就可以直接打包插件目录为rar格式,您的插件已经完成。这里,我们还有GBK的站长需要,因此我们需要进行转码。首先我们对我们的这个:discuz_plugin_mtest.xml文件进行改名,改名为:discuz_plugin_mtest_SC_UTF8.xml ,这里:SC表示简体中文 UTF8表示UTF8编码方式,然后使用编码转换工具,经这个XML文件转码后,重命名为对应的名字,放在这个目录下即可。编码转换工具我推荐 ConvertZ 这个工具,可以在网上搜索一下。至此,我们的转换工作就做完了!
    使用数据库
    我需要使用数据库,我的插件需要新建一个数据表怎么办?

    还记得我们刚才导出的那个XML文件么?我们需要修改这个XML文件的内容来实现我们的操作了。我们需要在

[html] view plaincopyprint?
  1. <item id="DATA"></item>  

中加上如下代码:

[html] view plaincopyprint?
  1. <item id="installfile"><![CDATA[install.php]]></item><item id="uninstallfile"><![CDATA[uninstall.php]]></item>  

上述代码分别表示:安装|卸载插件时会运行的文件,这两个文件都放在插件目录下即可,以下是一个示例:
<?php
/*
        mguide for DISCUZ X 1.0
        editor: monkee
        version:1.0
*/
if(!defined('IN_DISCUZ')) {
        exit('Access Denied');
}
$sql = <<<EOF
DROP TABLE IF EXISTS CDB_TABLE_SETTING;
CREATE TABLE CDB_TABLE_SETTING(
  `key` varchar(20) not null primary key,
  `value` text
) ENGINE=MYISAM DEFAULT CHARSET=DCHARSET;
EOF;


$sql=str_replace(array('CDB_TABLE_SETTING','DCHARSET'),array(DB::table('mguide_setting'),$_G['charset']=='utf-8'?'utf8':$_G['charset']),$sql);

foreach(explode(';',$sql) as $item){
        if(!empty($item))
                DB::query($item);
}

$finish = TRUE;
?>
原创粉丝点击