Discuz教程网

[插件制作] Discuz X2插件制作教程-最菜鸟级别的入门坎

  [复制链接]
authicon dly 发表于 2012-10-26 20:46:43 | 显示全部楼层 |阅读模式
转自:手把手教并个别地方重新排版 -- 终于也轮到我写教程指导后人了,在此感谢会员(sw08)的热心指导,同时也感谢曾经提供各种插件资料给我的论坛朋友们,是你们帮我跨过了插件的入门坎,也让我对插件有一点点认识,在此感谢各位!

         想想这几天为了自己网站的需求而不得不踏入插件制作的圈子,很多时候别人开发的插件往往不能满足自己的需求,可自己又不会这方面的知识,网站无法达到预想的效果,心里总有万分的无奈,无从下手。我作为一个菜鸟站长或PHP程序员来说,东西如果不能达到我想要得效果,我会想尽办法去解决,不然心里一直不爽!相信大家也会像我这样,现在就让我这个菜鸟来教你们开发处女作吧!

       有钱给钱,有力给力,别光看不回帖,这样不给力噢

       一、开发插件所需资料与工具
         1、DiscuzX2 插件机制   
游客,如果您要查看本帖隐藏内容请回复
         2、语言包编码转换工具 convertz  【百度一下】(专门用来处理多种编码的插件安装 )
         3、数据库管理工具 navicat   【百度一下】(方便数据库的查看与操作)
         4、网站的基本数据,这些数据包括:系统常量、全局变量、系统调用 ,首先从系统常量说起
            4.1、系统常量
                  DISCUZ_ROOT     //网站根目录
                  TIMESTAMP          //程序执行的时间戳
                  CHARSET             //程序的语言编码类型
                  IS_ROBOT           //是否是机器访问
                  FORMHASH          //HASH值
                  其余的可直接打印出来查看,如:
  1. <?php
  2. require_once './source/class/class_core.php';
  3. $discuz = & discuz_core::instance();
  4. $discuz->init();
  5. print_r(get_defined_c**tants());
  6. ?>
复制代码

4.2、全局变量
                 直接打印$_G即可得知,如:
  1. <?php
  2. require_once './source/class/class_core.php';
  3. $discuz = & discuz_core::instance();
  4. $discuz->init();
  5. print_r($_G);
  6. ?>
复制代码

4.3、数据库配置参数
                  直接打印$_G['config']['db']即可,如:
  1. <?php
  2. require_once './source/class/class_core.php';
  3. $discuz = & discuz_core::instance();
  4. $discuz->init();
  5. print_r($_G['config']['db']);
  6. ?>
复制代码
4.4、数据库操作
                  DB::table()           //增加了pre的数据库表名
                  DB::delete()           //删除表中数据
                  DB::insert()           //向表中插入数据
                  DB::update()           //更新表中数据
                  DB::fetch()           //配合DB::query来实现数据资源数据的获取
                  DB::query()           //执行一条数据库语句
                  DB::fetch_first()  //获取结果集的第一条记录

                  更多操作请查看文档:
游客,如果您要查看本帖隐藏内容请回复

         5、熟悉 ./source/function/function_admincp.php 管理后台文件里的函数,知道具体函数是实现什么功能效果
         6、了解和掌握基础通用的类、函数  
游客,如果您要查看本帖隐藏内容请回复

      、安全性处理
          1、文件的安全性
             所有与插件有关的程序,包括全部的前后台程序,因全部使用外壳调用,请务必在第一行加入
  1. if(!defined('IN_DISCUZ')) {
  2. exit('Access Denied');
  3. }
复制代码

以免其被 URL 直接请求调用,产生安全问题。

          2、对数值处理
             2.1、 intval();    //处理非负整数 ,如:$uid=intval($uid);
               注意,使用intval后,一定要想一想,自己这个变量是不是应该非负的?如果是的话,得加个判断语句,或者用abs,max等函数处理下
             2.2、 trim();      //去除左右空格, 如:$username=trim($username);
             2.3、 对于文字内容,记得使用htmlspecialchars(dhtmlspecialchars)
             2.4、 写入数据库时的注意事项
                   要进数据库的变量一定得addslashes(DZ内为daddslashes,如用DZ无须再次过滤,DZ已将所有$_POST和$_GET过滤),当然,如果你进的是数字(比如uid,并且已经intval过),或者是其他一些肯定不会出错的,那么你可以不做这一步。
             2.5、 在写sql语句时,变量一定得记得用'框起来。如果变量是字符串,不这么做会出错。如果是数字不这么做不会提示出错,但是有可能有注入的危险。
             2.6、 数组在运用前记得写$xxx = array();  原因很简单,防止用户提交恶意的值。

          3、语句查询优化
              在写SQL语句是尽量符合SQL规则,语句查询要相应的优化,有先有后;数据表要相应的创建索引,加快查询速度,这里不多说。

       、实例讲解之插件的前兆
           1、最先清楚需要开发什么功能的插件,插件机制是否能够开发,最后能否达到预期效果,否则一切都免谈了
           2、需要使用什么菜单、什么参数,配置哪些选项、数据结构如何设计、前后台实现哪些功能等等
           3、需要哪些函数,discuz内部是否有这功能的函数,尽量用内部的函数来达到预期效果
           4、最好不要改动discuz原有的布局,宁愿Coty一段代码出来也不要在原有的函数上添加功能,防止以后的升级问题
           5、尽最大能力去开发智能的插件,多用变量代替常量,增强程序的移植性,可维护性

       、实例讲解之基本配置
           1、安装全新的DiscuzX2
           2、打开 config/config_global.php 文件,在文件结尾添加以下代码开启插件设计者模式

235010ouurtruif6uj66rq.jpg

3、更新缓存(为了显示潜入点),刷新前台页面看看就知道什么叫嵌入点了,有嵌入点得地方就可以顺便输出内容,包括源码
               
23501188yg0zszppr8p183.jpg

、实例讲解之管理中心
1、这里以"会员注册后自动送100个金币"为例 (主要传授对数据库的操作)
2、填写插件最基本信息

               
235011899wuwpdp9t5xpww.jpg


(注意:提交完后记得在插件目录下建以标识符为名的文件夹,如: ./source/plugin/send_jinbi)



3、选择插件语言包
              
235011el3vvo3j8jptxf3g.jpg

235011llzddplcdqpl3scc.jpg

4、添加插件变量配置
               
235012jyigz2pvgpii8td8.jpg


具体可以点最后面的"详细"进入编辑


5、在插件列表中找到"新注册会员送100个金币"插件并启用
               
235012ygzxz4w4d64gjwdx.jpg
六、实例讲解之页面嵌入
         1、插件页面嵌入-普通版
            
000355fxmo0uxkjmox00cj.jpg


         2、在 ./source/plugin/send_jinbi/ 目录下建立 send_jinbi.class.php 文件,目的为了页面嵌入
  1. <?php
  2. if(!defined('IN_DISCUZ')) {
  3. exit('Access Denied');
  4. }

  5. class plugin_send_jinbi {
  6. function global_header() {
  7. global $_G;
  8. $sendConfig = array();
  9. $sendConfig = $_G['cache']['plugin']['send_jinbi']; //缓存插件变量值
  10. if( intval($sendConfig['status']) == 1 ) { //是否启动插件
  11. if( isset($_POST['regsubmit']) ) { //会员注册后
  12. $uid = intval($_G['member']['uid']);
  13. if( $uid ){
  14. $jinbi_num = intval($sendConfig['jinbi_num']); //送金币数量
  15. updatemembercount($uid,array("extcredits2" => $jinbi_num)); //更新金币数 (这个是function_core.php的现成函数)
  16. //这里可以进行任何数据库的操作
  17. }
  18. }
  19. }
  20. }
  21. }
  22. ?>
复制代码

3、基本上已经完成一大半了,你只要开启插件,然后更新缓存(可靠点),然后到前台去注册一个会员,则会自动送上100金币。
            
000355ja6y88a5szeyhz6h.jpg

       七、实例讲解之安装、卸载及升级
            1、 安装(install.php)、卸载(uninstall.php)程序中可随意设计页面的跳转,只要在插件安装、卸载结束时候输出添加 $finish = TRUE; 即可,脚本中可用 runquery() 函数执行 SQL 语句。
  1. <?php
  2. if(!defined('IN_DISCUZ')) {
  3. exit('Access Denied');
  4. }
  5. /*任意执行代码:开始*/
  6. //..........
  7. //..........
  8. /*任意执行代码:结束*/
  9. $finish = TRUE;
  10. ?>
复制代码
2、升级(upgrade.php)程序中可通过 $fromversion 和 $toversion 变量判断升级的具体版本号,并随意设计页面的跳转,只要在插件升级结束时候输出添加 $finish = TRUE;可,脚本中可用 runquery() 函数执行 SQL 语句。
  1. <?php
  2. if(!defined('IN_DISCUZ')) {
  3. exit('Access Denied');
  4. }
  5. /*任意执行代码:开始*/
  6. //..........
  7. //..........
  8. /*任意执行代码:结束*/
  9. $finish = TRUE;
  10. ?>
复制代码
3、其他功能请参考其他插件
八、实例讲解之插件语言包
           1、打开之前所创建的语言包文件(data/plugindata/send_jinbi.lang.php),添加以下代码,红色部分为插件的唯一标识符:
  1. <?php
  2. //程序脚本文件的语言包
  3. $scriptlang['send_jinbi'] = array(
  4. 'info' => '程序脚本文件的语言包'
  5. );

  6. //模版文件的语言包
  7. $templatelang['send_jinbi'] = array(
  8. 'info' => '模板文件的语言包'
  9. );

  10. //安装、升级、卸载脚本用的语言包
  11. $installlang['send_jinbi'] = array(
  12. 'info' => '安装、升级、卸载脚本用的语言包'
  13. );
  14. ?>
复制代码


2、调用语言包
                模版中调用模板文件语言包,通过 {lang send_jinbi:info} 方式调用。
                程序脚本中调用脚本文件语言包,通过 lang('plugin/send_jinbi', 'info') 方式调用。
                安装脚本中调用安装脚本文件语言包,通过 $installlang 变量直接获取。如 $installlang['info']。

          3、语言包的导出
000747ry85jeyykqz3jmp8.jpg

               导出后的语言包是:discuz_plugin_send_jinbi.xml
               接下来我们用编码转换工具 convertz  对discuz_plugin_send_jinbi.xml 分别转为:
               discuz_plugin_send_jinbi_SC_GBK.xml(简体中文GBK)
               discuz_plugin_send_jinbi_SC_UTF8.xml(简体中文UTF8)
               discuz_plugin_send_jinbi_TC_BIG5.xml(繁体中文BIG5)
               discuz_plugin_send_jinbi_TC_UTF8.xml(繁体中文UTF8)
               把这四个文件放到该插件 ./source/plugin/send_jinbi/  目录下

           4、安装时的效果图:
               
000747jm33fgm2u04352fu.jpg

       九、实例讲解之增加页面功能           

           1、在原有的页面上添加功能(这里以 注册 页面为例)
               
000747v1a1kt34ka3zxtvt.jpg


           2、在之前那个 ./source/plugin/send_jinbi/send_jinbi.class.php 的最后添加以下代码:
  1. class plugin_send_jinbi_member extends plugin_send_jinbi {//类名称plugin_send_jinbi_member 最后面的 member 应该是相应的模块名称吧!具体本人不怎么清楚,还望高人指点!总之它是会改变的,如果是论坛,则是 forum
  2.         function register_input() {  //函数名称其实就是前台页面嵌入点的名称
  3.                 $lang = lang('plugin/send_jinbi');  //获取此插件的语言包
  4.                 $bind = "<a href='javascript:void(0);' onClick="alert('别点我');">".$lang['info']."</a>";  //调用语言包显示
  5.                 return $bind;
  6.         }
  7. }
复制代码

           3、更新下缓存,再到前台注册页面看看效果
               
000747pqpla949pvls694o.jpg

          PS:写到这里,相信大家对插件基本上是有一点了解了吧!这几天来忙着工作大概就了解到这些知识,有了它们,我想要得网站效果都统统实现了,相信你们也会一样开发出自己心中的插件,只要你肯学,没有什么学不会;不说了,花了半天的时间写这篇教程,同时也巩固了自己的插件知识,朋友们!晚安



上一篇:Discuz X2.5 插件制作之后台常用函数详解
下一篇:怎么设置版块发帖分类信息颜色
authicon 亘古つ守侯珊 发表于 2012-10-27 13:22:29 | 显示全部楼层
给力呀!!
authicon  楼主| dly 发表于 2012-10-27 14:18:53 | 显示全部楼层
亘古つ守侯珊 发表于 2012-10-27 13:22
给力呀!!

你来干嘛
authicon 亘古つ守侯珊 发表于 2012-10-29 13:01:35 | 显示全部楼层
dly 发表于 2012-10-27 14:18
你来干嘛

我来给力撒 充电
authicon 3D老师 发表于 2012-10-30 16:09:21 | 显示全部楼层
我不得不顶了……
authicon 绝对零度 发表于 2012-10-31 17:19:33 | 显示全部楼层
看到这帖子真是高兴!
authicon 绝对零度 发表于 2012-11-6 18:26:26 | 显示全部楼层
看到这帖子真是高兴!我真的很感悟……
authicon waeyy 发表于 2012-11-7 19:01:42 | 显示全部楼层
给力真是难得给力的帖子啊。
authicon dylanmine 发表于 2012-11-16 16:08:19 | 显示全部楼层
我真的很感悟…… 强烈支持楼主ing……
authicon 联创科技 发表于 2012-11-16 23:27:24 | 显示全部楼层
谢谢分享。。。 强烈支持楼主ing……
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

1314学习网 ( 浙ICP备10214163号 )

GMT+8, 2024-4-26 01:25

Powered by Discuz! X3.4

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表