【weiphp微信开发教程】留言板插件开发详解

基于weiphp框架的留言板插件教程:

1、功能分析

传统的留言板应该具有发布留言、查看留言、回复留言、管理留言等功能,本教程开发的是最基本的留言板,仅包含发布留言和查看留言两个功能,根据功能用bootstrap制作的前台页面样式如下:

2、新建weiphp插件

在第一步我们根据留言板的功能需求设计了前台效果页面,那么接下来的步骤就是根据效果来逐步开发weiphp插件了

第一步,在weiphp后台管理页面创建一个插件,记得把是否需要配置项和是否需要管理列表两个选项都选为“是”

第二步,安装创建好的插件,点击插件右侧的安装链接即可

回到weiphp前台管理页面,点击左侧的留言板就能看到已经安装好的留言板插件了

3、查看代码结构

插件创建成功后,weiphp框架会自动在Addons目录下生成一个插件文件夹,本教程生成一个liuyanban文件夹,liuyanban目录下包
括Controller、Model、View三个文件夹和config.php、LiuyanbanAddon.class.php两个文件。
Controller里面一般写逻辑处理代码,包括数据插入、数据查询等功能代码,Model里面主要写一些与微信交互的代码,View里面放前台模板。
config.php是配置文件,LiuyanbanAddon.class.php是插件信息文件,一般不需要修改。

4、测试插件是否可用

打开Model/WexinAddonModel.class.php

添加测试代码。最简单的测试代码为$this->replyTest(‘hello world‘);

下图第13、第14行代码为自己写上的测试代码,当用户在微信中回复“留言板”时,返回系统时间加提示信息

在微信中测试插件是否可用

bingo,插件正常可用,我们接着往下走

5、创建配置文件

打开config.php,写上下图所示配置代码

重新打开留言板管理界面,即可看到配置项设置成功

打开Model/WexinAddonModel.class.php,重新编辑微信响应代码(第15-25行),返回图文消息

重新在微信中测试留言板插件

返回单图文消息,bingo,继续往下走

6、导入前台模板

第一步,下载前台模板。最开始看到的那个前台页面我已经上传到了我的百度网盘,可以从这里下载:http://yun.baidu.com/s/1sjJgwEx

第二步,将下载的前台模板上传到View/default/Liuyanban文件夹下面

在Controller/LiuyanbanController.class.php中写上输出前台的代码

点击微信中回复的图文消息,就可以进入到前台首页了

现在看到的首页只是一个静态的html页面,点击“发布>>”没有任何跳转,我们需要对“发布>>”添加一个跳转链接

打开index.html页面,在第22行把“发布>>”的href链接改成下图所示,即跳转到当前控制器下的liuyan()方法,并传递token和uid两个参数。BTW:{:U(‘‘,‘‘)}为thinphp生成url的模板方法,不懂的请自行百度

前面在写LiuyanController的时候我们写了一个liuyan()方法,该方法没有进行任何的逻辑处理,只是显示出留言页面,即跳转到
liuyan.html。改好href的链接地址后在index.html中点击右上角的“发布>>”即可跳转到下图所示留言发布页面

同样,发布留言右上角的“查看>>”链接也不可跳转,我们在第19行把href改成下图所示

7、数据模型分析与创建

数据库设计毫无疑问是IT技术中的重中之重,关于数据库的知识请自行百度mysql教程学习。weiphp提供了一个方便的web端管理数据表模型,针对最开始我们看到的前台页面,我们来看一下发布留言页面有哪些input字段

分析可知本留言板插件只需要留言者姓名(name)、留言内容(content)两个可见的字段,同时要有留言时间(cTime)、留言所在的公众号Token(token)、留言者的用户UID(uid)。知道了这些,我们便开始设计数据库模型。

打开weiphp后台管理页面,新建liuyanban数据模型,下面的截图显示的模型标识为liuyan_info,建议大家改为liuyanban,
因为只有数据模型名为liuyanban(跟插件名一致)的时候,默认的weiphp前台留言板管理列表中才能显示数据,关于怎么更改默认的数据显示页面
与新建多个不同的数据模型不在本教程讲述的范围内,所以大家还是把下图的数据模型标识写为liuyanban吧。

创建好了数据模型之后我们便开始新建留言板插件所需的字段,点击数据模型操作界面右边的字段管理->新建字段即可。新建前面提到的token、uid、cTime、name、content五个字段,注意在字段新建页面的“高级”选项中添加字段自动完成规则,token添加get_token(),uid添加get_mid(),cTime添加time()

这就是我们创建好的留言板插件所需的全部字段了

回到模型管理页面,在liuyanban模型的右边点击编辑,将liuyanban模型的列表定义改为下图所示,这样是为了方便留言板前台管理页面能够显示数据

回到留言板前台管理页面,就可以看到显示数据的字段与操作了(留言者、留言内容、留言时间、操作)

到此为止整个数据库设计过程完成,接下来就是建立逻辑处理代码操作数据了

8、查询用户信息

打开Controller/LiuyanbanController.class.php,在liuyan()方法内写上下图所示16、17、18三行代
码,及根据用户的uid查询用户的信息,并把信息输出到留言发布页面的留言者姓名填写框中。这样做的目的是为了方便用户操作,只要绑定过一次个人信息,留
言的时候就不需要重复填写姓名了

在liuyan.html页面中将留言者姓名(name)的input框的value值改为用户的姓名,{$user.nickname}为输出用户的昵称

在进入发布留言页面的时候只要我们以前绑定过个人信息,在留言者姓名输入框中就能自动显示绑定的昵称了

9、插入留言数据

在liuyan()方法中写上数据处理代码(第21-34行),当用户提交留言数据之后就把留言数据插入到liuyanban数据表中

在留言页面插入几条测试数据之后回到留言板插件管理页面,就能看到用户提交的留言数据了。

10、显示留言信息

在index()方法中新建数据查询代码,把liuyanban数据表中的数据提取出来并显示到index.html前台模板

在index.html中用thinkphp模板标签<volist>把留言数据循环输出,BTW:weiphp是基于thinkphp开发
的,所有的thinkphp标签在weiphp中都是可用的,因此要学会weiphp插件开发的关键是要懂基本的thinkphp知识

打开index.html,就可以看到所有的留言数据了

至此,整个的weiphp留言板插件开发就完成了,查看此插件效果请在“艾豆乐园”微信公众平台中回复“留言板”,至于后面的如何将插件打包下载,上传到新的weiphp框架或者是导出数据模型,请各位自行查看weiphp官方文档。

转自:http://my.oschina.net/ecnu/blog/303753

如非特别注明,本站内容均为领悟书生原创,转载请务必注明作者和原始出处。
本文地址:http://www.656463.com/article/MZvINf.htm

时间: 2024-10-12 13:39:03

【weiphp微信开发教程】留言板插件开发详解的相关文章

Android开发教程复选框详解

前面麦子学院的android开发老师给大家介绍过关于Android开发教程单选框详解,今天麦子学院的android开发老师给大家讲android复选框的一些基本内容. ●设置复选框的Check状态的时候,调用setChecked()方法 ●追加Android复选框被选择时处理的时候, 1.调用setOnCheckedChangeListener()方法,并把CompoundButton.OnCheckedChangeListener实例作为参数传入 2.在CompoundButton.OnChe

麦子android开发教程:Android开发框架详解

在麦子学院里有很多初学android开发的同学都在问安卓的开发框架问题,下面跟着麦子学院的android老师来看看相关的代码: Java代码 1.   publicclass App extends Activity { 2. 3.       public App () {//构造函数不用说了 4.      } 5. 6.       public void onCreate(Bundle savedInstanceState) {//界面初始化的时候调用 7.          super

微信公众平台开发之留言板

 微信公众平台开发之留言板是方便用户互相之间交流的最好方法.关注微信公号的用户之间是不能进行对话的.为了方便用户之间的交流留言板起到了非常大的作用.当用户进入留言板后能够在上面留言,互相回复.这样全部的用户都能看到上面的留言呀,大家相互之间就能够对话了.以下就由微时代来简介一下留言板功能吧: 1.在微时代后台配置"留言"关键词的回复内容,设置好该内容以后当用户回复"留言"的时候就能够进入留言板界面了 2.查看用户的留言.当然还能够自己加入留言,也能够对用户留言进行回

【写给小部员的基础微信开发教程2】php介绍及基础

//深夜码字有点困- -. 前言:此为本人所写的第一篇教程,本人将尽可能保证文中相关名词的规范与准确,但由于本人技术知识所限,难免会有所错误,恳请各位读者批评指正,一起交流学习,谢谢. 注:本教程适用于已对 html有基础认知 以及学习过 c++或c或java等编程语言的 同学. 本次教程 php基础 的内容如下: 一.概述 二.应用场景 三.基础语法 以下为正文: 一.概述 php的定义:PHP(Hypertext Preprocessor 超文本预处理器) 是一种创建动态交互性站点的强有力的

jsp+mysql开发网站留言板源代码下载

原文:jsp+mysql开发网站留言板源代码下载 源代码下载地址:http://www.zuidaima.com/share/1550463448304640.htm jsp+mysql开发网站留言板源代码下载

嵌入式开发平台 迅为6818开发板接口详解

迅为八核iTOP-6818开发板接口详解: iTOP-4418接口图: iTOP-6818核心板: iTOP-6818开发板接口详解: 1.POWER电源接口 电源输入为5V/2A+,给核心板AXP228电源管理芯片提供5V电源,给底板供电. 2. SWITCH电源开关 轻触电源开关可以控制开发板电源通断. 3. 拨码开关 3位拨码开关控制4418启动模式. 4. 模数转换 A/D模数转换,调整滑动变阻器,模拟量可以通过转换口检测到. 5. JTAG接口 保留JTAG接口,有需要的用户可以进行扩

.NET源码保护控件VMProtect免费下载及使用教程脱壳等功能详解

原文来自VMProtect龙博方案网www.fanganwang.com VMProtect是一款全新的软件保护工具.与其它大部分的保护程序不同,VMProtect可修改程序的源代码.VMProtect可将被保护文件中的部分代码转化到在虚拟机(以下称作VM)上运行的程序(以下称作bytecode)中.您同样可把VM想象为具备命令系统的虚拟处理器,该命令系统与Intel 8086处理器所使用的完全不同.例如,VM没有负责比较2个操作数的命令,也没有有条件与无条件的移转等.就象您现在看到的,黑客必须

JQ插件开发详解

jQuery插件的开发包括两种: 一种是类级别的插件开发,即给jQuery添加新的全局函数,相当于给jQuery类本身添加方法.jQuery的全局函数就是属于jQuery命名空间的函数,另一种是对象级别的插件开发,即给jQuery对象添加方法.下面就两种函数的开发做详细的说明. 1.类级别的插件开发 类级别的插件开发最直接的理解就是给jQuery类添加类方法,可以理解为添加静态方法.典型的例子就是$.AJAX()这个函数,将函数定义于jQuery的命名空间中.关于类级别的插件开发可以采用如下几种

【10.2.3】ArcGIS Runtime for Android搭建开发环境过程中问题详解

一.Visual Studio Ultimate2012安装过程问题 1.问题描述 安装完成后,您将看到一条消息,指示安装程序已完成,但并不是所有的功能具有已正确安装,以及以下警告消息: Microsoft Web Deploy 3.0 所需的证书不在有效期内根据当前系统时钟或签名文件中的时间戳验证时. 2.解决方案 修改电脑系统时间为2013年7月,断网后重新安装,成功后再联网. Visual Studio Ultimate2012激活密钥:RBCXF-CVBGR-382MK-DFHJ4-C6