首页 > 代码库 > PHP微信公众开发笔记(八)
PHP微信公众开发笔记(八)
PHP微信公众开发笔记系列
日期:2014.9.6
今天主要要做:建立关键词数据库、超时机制、优化的关键词匹配、表情信息数据库
要注意的:PHP echo之后并没有返回?还会继续执行??
2014.9.11整理笔记:
写这个笔记的时候,在赶功能,所以也就是简单的记几笔当时的工作内容,现在功能开发得差不多了,就来整理之前的笔记。当时就很简单的记录了上文的那几句。
这天是周六,不加班了在租的房子里歇着。因为要过中秋了,在深圳的姐这天会过来我这边过节,所以这天也没多少时间来写功能。早上早起去跑步,然后回来就开始折腾了(现在想想,没准以后自己真会成为一个工作狂了)。这天做的功能是在数据库中建立一个关键词数据表、表情信息数据表、加入了超时机制和优化了关键词匹配。
一、关键词数据表
这个数据表存储的信息主要是我之前做关键词过滤、捕获时用到的一些关键词。因为想方便管理,所以想一想将这些放到数据库中去,然后写一个函数调取这些信息,再去做匹配,这样我就不需要将所有的信息都写死在代码中,会更灵活点。有了这个想法之后,便开始整理这个数据表了。
关于数据库的操作没什么特意要提的,这里主要是记录下代码中的操作吧:
1、首先是获得所有的关键词:
这个很简单,就是将数据库中关键词数据表的整个数据都弄出来:
select * from xxx 选取数据表xxx的信息;
这样就得到了所有的关键词信息了。
2、得到了关键词数据表的信息之后,就是做关键词的匹配了:
后续的操作就是直接使用的之前的代码,我这里只是理了一下结构而已。提到的优化了关键词
二、表情数据库
回复信息是可以回复表情的,在这里我不是用的emoji表情,而是最普通的那种,比如说"微笑" 就用"/::)"这个来表示,我建立的表情数据表也就是以微笑作为关键词,以"/::)"为值,然后加上一个表情类型,总共这三个字段。使用的时候,使用直接输入微笑,然后得到其值再回复,就可以使用了。也只是涉及到数据库的操作,在这里就不多啰嗦了。
三、超时机制
因为公众号使用了$_SESSION来存储如验证用户身份等信息,还有选择的菜单类型。就感觉有必要定期清理这些,比如说用户选择了菜单,然后长时间没有用了,那么就最好是下一次再使用的时候没有在菜单里了,而应该是退出了。有这样一个考虑,我就在网上查阅了相关了资料:要么就是定期全部清理所有的$_SESSION,要么就是定期清除单个$_SESSION。要做到定期,那么就需要知道时间,结合我之前做手游项目时用到的东西,想做定期无非也就是记住开启的时间,然后在每次使用的时候做判断就可以了。
这样就实现了我所谓的超时机制了。
PHP学习记录:
在echo 之后,函数还是会执行下去嘛?之前,我回复信息并不是统一控制,可能某些模块我会直接回复了。但是我发现,即使我用echo回复了消息了,还是会执行echo之后的代码段,这不知道是啥情况。
日期:2014.9.6
今天主要要做:建立关键词数据库、超时机制、优化的关键词匹配、表情信息数据库
要注意的:PHP echo之后并没有返回?还会继续执行??
2014.9.11整理笔记:
写这个笔记的时候,在赶功能,所以也就是简单的记几笔当时的工作内容,现在功能开发得差不多了,就来整理之前的笔记。当时就很简单的记录了上文的那几句。
这天是周六,不加班了在租的房子里歇着。因为要过中秋了,在深圳的姐这天会过来我这边过节,所以这天也没多少时间来写功能。早上早起去跑步,然后回来就开始折腾了(现在想想,没准以后自己真会成为一个工作狂了)。这天做的功能是在数据库中建立一个关键词数据表、表情信息数据表、加入了超时机制和优化了关键词匹配。
一、关键词数据表
这个数据表存储的信息主要是我之前做关键词过滤、捕获时用到的一些关键词。因为想方便管理,所以想一想将这些放到数据库中去,然后写一个函数调取这些信息,再去做匹配,这样我就不需要将所有的信息都写死在代码中,会更灵活点。有了这个想法之后,便开始整理这个数据表了。
关于数据库的操作没什么特意要提的,这里主要是记录下代码中的操作吧:
1、首先是获得所有的关键词:
这个很简单,就是将数据库中关键词数据表的整个数据都弄出来:
select * from xxx 选取数据表xxx的信息;
然后将得到的信息存储至一个二维数组中:
这样就得到了所有的关键词信息了。
2、得到了关键词数据表的信息之后,就是做关键词的匹配了:
首先我需要得到匹配到的这一行数据信息,然后再做下一步的工作。因为这里的关键词是将诸如地址、电话、老家之类的存在数据库,而用户发送过来的可能是XX电话、XX老家,所以在这里判断不是之前用的那个in_array,而是使用的strstr()函数来做判断的:
具体代码如上图所示,这样我就得到了这个关键词在数据表中的数据行了,然后我根据其类型再做下一步工作(数据表中包含关键词、关键词类型这两个字段,有这两个信息我就可以根据关键词类型做相应的操作了):
后续的操作就是直接使用的之前的代码,我这里只是理了一下结构而已。提到的优化了关键词
二、表情数据库
回复信息是可以回复表情的,在这里我不是用的emoji表情,而是最普通的那种,比如说"微笑" 就用"/::)"这个来表示,我建立的表情数据表也就是以微笑作为关键词,以"/::)"为值,然后加上一个表情类型,总共这三个字段。使用的时候,使用直接输入微笑,然后得到其值再回复,就可以使用了。也只是涉及到数据库的操作,在这里就不多啰嗦了。
三、超时机制
因为公众号使用了$_SESSION来存储如验证用户身份等信息,还有选择的菜单类型。就感觉有必要定期清理这些,比如说用户选择了菜单,然后长时间没有用了,那么就最好是下一次再使用的时候没有在菜单里了,而应该是退出了。有这样一个考虑,我就在网上查阅了相关了资料:要么就是定期全部清理所有的$_SESSION,要么就是定期清除单个$_SESSION。要做到定期,那么就需要知道时间,结合我之前做手游项目时用到的东西,想做定期无非也就是记住开启的时间,然后在每次使用的时候做判断就可以了。
在实现上,首先我是记录存储某个$_SESSION的时间,比如说验证用户身份的时间:
上图出现的psa_time()也只是对系统提供的time()函数的一个包装而已。这样我就获得了验证身份的时间,然后我在每次用户操作的时候获得当前时间,用来跟记录的这个时间做对比:
这样就实现了我所谓的超时机制了。
PHP学习记录:
在echo 之后,函数还是会执行下去嘛?之前,我回复信息并不是统一控制,可能某些模块我会直接回复了。但是我发现,即使我用echo回复了消息了,还是会执行echo之后的代码段,这不知道是啥情况。
PHP微信公众开发笔记(八)
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。