|
可以到百度文库下载PDF教程,这样可以方便各位携带,随带随学哈!
下载链接:http://wenku.baidu.com/view/513b590690c69ec3d5bb758f.html?st=1
终于也轮到我写教程指导后人了,在此感谢会员(sw08)的热心指导,同时也感谢曾经提供各种插件资料给我的论坛朋友们,是你们帮我跨过了插件的入门坎,也让我对插件有一点点认识,在此感谢各位!
想想这几天为了自己网站的需求而不得不踏入插件制作的圈子,很多时候别人开发的插件往往不能满足自己的需求,可自己又不会这方面的知识,网站无法达到预想的效果,心里总有万分的无奈,无从下手。我作为一个菜鸟站长或PHP程序员来说,东西如果不能达到我想要得效果,我会想尽办法去解决,不然心里一直不爽!相信大家也会像我这样,现在就让我这个菜鸟来教你们开发处女作吧!
有钱给钱,有力给力,别光看不回帖,这样不给力噢
一、开发插件所需资料与工具
1、DiscuzX2 插件机制 http://dev.discuz.org/wiki/#.E6.8F.92.E4.BB.B6.E6.9C.BA.E5.88.B6
2、语言包编码转换工具 convertz 【百度一下】(专门用来处理多种编码的插件安装 )
3、数据库管理工具 navicat 【百度一下】(方便数据库的查看与操作)
4、网站的基本数据,这些数据包括:系统常量、全局变量、系统调用 ,首先从系统常量说起
4.1、系统常量
DISCUZ_ROOT //网站根目录
TIMESTAMP //程序执行的时间戳
CHARSET //程序的语言编码类型
IS_ROBOT //是否是机器访问
FORMHASH //HASH值
其余的可直接打印出来查看,如:- <?php
- require_once './source/class/class_core.php';
- $discuz = & discuz_core::instance();
- $discuz->init();
- print_r(get_defined_constants());
- ?>
复制代码 4.2、全局变量
直接打印$_G即可得知,如:- <?php
- require_once './source/class/class_core.php';
- $discuz = & discuz_core::instance();
- $discuz->init();
- print_r($_G);
- ?>
复制代码 4.3、数据库配置参数
直接打印$_G['config']['db']即可,如:- <?php
- require_once './source/class/class_core.php';
- $discuz = & discuz_core::instance();
- $discuz->init();
- print_r($_G['config']['db']);
- ?>
复制代码 4.4、数据库操作
DB::table() //增加了pre的数据库表名
DB::delete() //删除表中数据
DB::insert() //向表中插入数据
DB::update() //更新表中数据
DB::fetch() //配合DB::query来实现数据资源数据的获取
DB::query() //执行一条数据库语句
DB::fetch_first() //获取结果集的第一条记录
更多操作请查看文档:http://dev.discuz.org/wiki/index ... E%E5%BA%93%E7%B1%BB
5、熟悉 ./source/function/function_admincp.php 管理后台文件里的函数,知道具体函数是实现什么功能效果
6、了解和掌握基础通用的类、函数 http://dev.discuz.org/wiki/#.E5. ... 1.E5.87.BD.E6.95.B0
二、安全性处理
1、文件的安全性
所有与插件有关的程序,包括全部的前后台程序,因全部使用外壳调用,请务必在第一行加入
if(!defined('IN_DISCUZ')) {
exit('Access Denied');
}
以免其被 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 文件,在文件结尾添加以下代码开启插件设计者模式- $_config['plugindeveloper'] = 2; // 1 表示开启插件设计者模式 ; 2 表示开启插件设计者模式且显示前台页面的潜入点
复制代码
3、更新缓存(为了显示潜入点),刷新前台页面看看就知道什么叫嵌入点了,有嵌入点得地方就可以顺便输出内容,包括源码
五、实例讲解之管理中心
1、这里以“会员注册后自动送100个金币”为例 (主要传授对数据库的操作)
2、填写插件最基本信息
3、选择插件语言包
4、添加插件变量配置
具体可以点最后面的"详细"进入编辑
5、在插件列表中找到"新注册会员送100个金币"插件并启用
|
本帖子中包含更多资源
您需要 登录 才可以下载或查看,没有账号?立即注册
x
|