首页 / 专利库 / 人工智能 / 自动音乐标记 / 微信公众平台下的个性化书屋

微信公众平台下的个性化书屋

阅读:140发布:2020-05-26

专利汇可以提供微信公众平台下的个性化书屋专利检索,专利查询,专利分析的服务。并且本 发明 公开了一种微信公众平台下的个性化书屋,书屋Web应用系统选择Java作为开发语言,基于开源SDK控件,从微信公众平台发送的XML消息解析、与书屋业务系统建立信息查询和将获取的查询信息进行XML封装等方面,实现书屋业务嵌入微信的应用。本发明对建设校园文化,推动校园建设发展具有积极的意义。,下面是微信公众平台下的个性化书屋专利的具体信息内容。

1.一种微信公众平台下的个性化书屋,其特征在于,包括:
用户关注书屋微信公众帐号后,通过客户端在微信公众平台向所述公众账号发送请求
微信服务器通过超文本传输协议提交方式以可扩展标记语言格式将所述请求发送给公众账号服务器;
所述公众账号服务器先对所述请求进行身份校验,确保来自微信服务器,对所述校验成功的请求进行解析,将解析出来的请求进行业务逻辑处理,把处理结果转换成所述可扩展标记语言格式的字符串后发送给所述微信服务器;其中,所述身份校验包括:获取所述请求的4个参数,签名、时间戳、随机数和随机字符串;将令牌、所述时间戳和所述随机数按字典序排序;将排序后的3个参数按顺序拼接成一个字符串,并对所述字符串进行安全哈希算法1加密;将经过所述安全哈希算法1加密后的字符串与所述签名参数进行对比,如果相等则该请求来自微信服务器,需要原样返回所述随机字符串参数;
所述微信服务器将所述处理结果发送给用户所述客户端。
2.如权利要求1所述微信公众平台下的个性化书屋,其特征在于:所述用户关注所述书屋微信公众账号时,所述公众账号服务器自动向读者发送欢迎词和操作说明;所述用户发送的请求包括用户学号,所述公众账号服务器接收并解析所述请求,获取所述用户学号和微信账号,存储在我的结构化查询语言数据库中,为信息查询模调用学号做准备;所述用户取消所述书屋微信公众账号关注后,将从所述数据库中删除存储的所述用户学号相关信息。
3.如权利要求1-2所述微信公众平台下的个性化书屋,其特征在于:所述公众账号服务器将所述请求消息类型分为,文本、图片、语音、视频、地理位置、链接和事件推送;将所述业务逻辑处理类型分为,订阅、取消订阅、扫描带参数二维码、上报地理位置和自定义菜单;将所述处理结果消息类型分为,文本、图片、语音、视频、音乐和图文。
4.如权利要求3所述微信公众平台下的个性化书屋,其特征在于:所述公众账号服务器通过网上书店畅销排行榜定期为所述用户推荐热书籍。
5.如权利要求4所述微信公众平台下的个性化书屋,其特征在于:所述公众账号服务器通过基于标签的协同过滤推荐算法为所述用户推荐书籍,包括:
将用户-标签-书籍三维关系分解为用户-标签、标签-书籍2个二维关系,在用户-标签关系中计算用户对标签标注频率和标签对用户的逆向频率,在标签与书籍关系中计算标签对书籍标注频率和频率对标签的逆向频率;构建用户对资源的兴趣模型,分别计算用户与标签的关联度、书籍与标签的关联度,再计算用户对书籍的兴趣;计算书籍的相似度,根据不同书籍被同一标签标注的次数评估书籍之间的相似度,采用Jaccard系数计算得到书籍的相似度;预测目标用户对待推荐新书籍的兴趣度,根据构建的用户对书籍的兴趣模型,以及待推荐新资源与已标注书籍的相似度计算得到目标用户对新书籍的兴趣度;将目标用户对于新书籍的预测兴趣度按照从大到小排序,取出排名靠前的书籍作为最终推荐集并输出。
6.如权利要求5所述微信公众平台下的个性化书屋,其特征在于:采用Java开发语言,基于开源SDK控件进行开发;选择Eclipse开源工具,使用开源框架Dom4j和XStream来实现XML消息的解析与封装工作。
7.如权利要求6所述微信公众平台下的个性化书屋,其特征在于:为所述用户提供推荐好友的功能,增加自定义菜单权限,采用菜单向导方式,并利用学校组织者身份对所述书屋微信公众帐号进行认证。

说明书全文

微信公众平台下的个性化书屋

技术领域

[0001] 本发明涉及一种微信公众平台下的个性化书屋,属于数字化信息技术领域。

背景技术

[0002] 随着现在通讯技术飞速发展,作为时下最热的免费即时手机通讯聊天软件,微信成为一个很好的移动信息传播交互平台,而微信公众平台是在微信的基础上新增的功能模,是面向一些机构推出的合作推广业务,如政府、企业、媒体等,它可以通过推送文字、图片、语音、视频、音乐等消息、设定自动回复或一对一交流等方式,向关注用户提供更好、更全面的服务,从而达到推广的目的。目前,将微信公众平台作为高校图书馆的借阅拓展渠道,是时下发展的趋势。目前,国内对微信公众平台下的类似书屋基本实现能发表需求书籍和捐赠闲置书籍,但未设置有区域性校园级别权限的保障点。以“共享书屋”为关键词能查找到少量小程序和微信公众号,但对于高校学生之间,所在高校共享图书微信公众平台欠缺,且国内对类似书屋免费借阅城市化模式也尚处于开始阶段,尚未成型。
[0003] 从平台技术上看,微信官网提供了详细的技术文档和SDK(软件开发工具包),但是按照腾讯官方技术文档开发效率低下,且编程难度较大。目前,腾讯官方只提供了基于PHP环境的SDK,因此,出现了很多第三方SDK。尽管如此,目前仍然较少发现开源SDK的应用设计,而且在检索的设计类文档中,主要是基于PHP环境进行开发。

发明内容

[0004] 本发明的一个目的是解决至少上述问题,并提供至少后面将说明的优点。
[0005] 本发明还有一个目的是提供一种基于微信公众平台的个性化书屋,书屋Web应用系统,选择Java作为开发语言,基于开源SDK控件,从微信公众平台发送的XML消息解析、与书屋业务系统建立信息查询和将获取的查询信息进行XML封装等方面,实现书屋业务嵌入微信的应用。本发明对建设校园文化,推动校园建设发展具有积极的意义。
[0006] 为了实现根据本发明的这些目的和其它优点,提供了
[0007] 一种微信公众平台下的个性化书屋,其特征在于,包括:
[0008] 用户关注书屋微信公众帐号后,通过客户端在微信公众平台向所述公众账号发送请求
[0009] 微信服务器通过超文本传输协议提交(HTTPPOST)方式以可扩展标记语言(XML)格式将所述请求发送给公众账号服务器;
[0010] 所述公众账号服务器先对所述请求进行身份校验,确保来自微信服务器,对所述校验成功的请求进行解析,将解析出来的请求进行业务逻辑处理,把处理结果转换成所述可扩展标记语言格式的字符串后发送给所述微信服务器;其中,所述身份校验包括:获取所述请求的4个参数,签名(signature)、时间戳(timestamp)、随机数(nonce)和随机字符串(echostr);将令牌(token)、所述时间戳和所述随机数按字典序排序;将排序后的3个参数按顺序拼接成一个字符串,并对所述字符串进行安全哈希算法1(Secure Hash Algorithm 1,sha1)加密;将经过所述安全哈希算法1加密后的字符串与所述签名参数进行对比,如果相等则该请求来自微信服务器,需要原样返回所述随机字符串参数;
[0011] 所述微信服务器将所述处理结果发送给用户所述客户端。
[0012] 优选的,微信公众平台下的个性化书屋中:所述用户关注所述书屋微信公众账号时,所述公众账号服务器自动向读者发送欢迎词和操作说明;所述用户发送的请求包括用户学号,所述公众账号服务器接收并解析所述请求,获取所述用户学号和微信账号,存储在我的结构化查询语言(MySQL)数据库中,为信息查询模块调用学号做准备;所述用户取消所述书屋微信公众账号关注后,将从所述数据库中删除存储的所述用户学号相关信息。
[0013] 优选的,微信公众平台下的个性化书屋中:所述公众账号服务器将所述请求消息类型分为,文本、图片、语音、视频、地理位置、链接和事件推送;将所述业务逻辑处理类型分为,订阅、取消订阅、扫描带参数二维码、上报地理位置和自定义菜单;将所述处理结果消息类型分为,文本、图片、语音、视频、音乐和图文。
[0014] 优选的,微信公众平台下的个性化书屋中:所述公众账号服务器通过网上书店畅销排行榜定期为所述用户推荐热门书籍。
[0015] 优选的,微信公众平台下的个性化书屋中:所述公众账号服务器通过基于标签的协同过滤推荐算法为所述用户推荐书籍,包括:
[0016] 将用户-标签-书籍三维关系分解为用户-标签、标签-书籍2个二维关系,在用户-标签关系中计算用户对标签标注频率和标签对用户的逆向频率,在标签与书籍关系中计算标签对书籍标注频率和频率对标签的逆向频率;构建用户对资源的兴趣模型,分别计算用户与标签的关联度、书籍与标签的关联度,再计算用户对书籍的兴趣;计算书籍的相似度,根据不同书籍被同一标签标注的次数评估书籍之间的相似度,采用Jaccard系数计算得到书籍的相似度;预测目标用户对待推荐新书籍的兴趣度,根据构建的用户对书籍的兴趣模型,以及待推荐新资源与已标注书籍的相似度计算得到目标用户对新书籍的兴趣度;将目标用户对于新书籍的预测兴趣度按照从大到小排序,取出排名靠前的书籍作为最终推荐集并输出。
[0017] 优选的,微信公众平台下的个性化书屋中:采用Java开发语言,基于开源SDK控件进行开发;选择Eclipse开源工具,使用开源框架Dom4j和XStream来实现XML消息的解析与封装工作。
[0018] 优选的,微信公众平台下的个性化书屋中:为所述用户提供推荐好友的功能,增加自定义菜单权限,采用菜单向导方式,并利用学校组织者身份对所述书屋微信公众帐号进行认证。
[0019] 本发明至少包括以下有益效果:
[0020] 1、可以嵌入微信平台;
[0021] 2、以最小成本开发利用现有资源;
[0022] 3、提供个性化服务,方便用户查询书籍信息;
[0023] 4、提供高校共享图书微信公众平台,推动校园建设发展。
[0024] 本发明的其它优点、目标和特征将部分通过下面的说明体现,部分还将通过对本发明的研究和实践而为本领域的技术人员所理解。附图说明
[0025] 图1为本发明所述微信公众平台下的个性化书屋的框架图。

具体实施方式

[0026] 下面结合附图对本发明做进一步的详细说明,以令本领域技术人员参照说明书文字能够据以实施。
[0027] 应当理解,本文所使用的诸如“具有”、“包含”以及“包括”术语并不排除一个或多个其它元件或其组合的存在或添加。
[0028] 本发明的微信公众平台下的个性化书屋,包括:
[0029] 用户关注书屋微信公众帐号后,应用系统自动向读者发送欢迎词和操作指令。用户通过客户端在微信公众平台向所述公众账号发送请求,该请求包含读者学号;
[0030] 微信服务器通过超文本传输协议提交(HTTPPOST)方式以可扩展标记语言(XML)格式将所述请求发送给公众账号服务器。
[0031] 所述公众账号服务器先对所述请求进行身份校验,确保来自微信服务器,对所述校验成功的请求进行解析,获取学号和微信账号,存储在我的结构化查询语言(MySQL)数据库中,为信息查询模块调用学号做准备。接着分析指令内容,将分析出来的请求进行业务逻辑处理,启用相应的信息查询模块,与数据库建立查询链接,得到查询结果。把处理结果转换成所述可扩展标记语言格式的字符串后发送给所述微信服务器。所述用户取消所述书屋微信公众账号关注后,将从所述数据库中删除存储的所述用户学号相关信息。
[0032] 从腾讯官方文档接入指南可以了解到,要使用公众平台开发模式,必须先填写接口配置信息中的URL和Token,这就要求开发者拥有公网服务器资源,并且按照开发者文档完成相关程序的开发。其次,进行“验证URL有效性”,也就是说,我们要开发的请求校验程序必须能够处理HTTP GET请求,而且要对请求者进行身份校验,以确保请求来自微信服务器。请求校验流程如下:
[0033] 获取所述请求的4个参数,签名(signature)、时间戳(timestamp)、随机数(nonce)和随机字符串(echostr);将令牌(token)、所述时间戳和所述随机数按字典序排序;将排序后的3个参数按顺序拼接成一个字符串,并对所述字符串进行安全哈希算法1(Secure HashAlgorithm 1,sha1)加密;将经过所述安全哈希算法1加密后的字符串与所述签名参数进行对比,如果相等则该请求来自微信服务器,需要原样返回所述随机字符串参数。
[0034] 所述微信服务器将所述处理结果发送给用户所述客户端。
[0035] 为实现上面请求校验流程,首先新建一个Web项目,在项目的src目录下创建一个普通Java类SignUtil,使用这个类对请求校验流程的实现进行了封装,可以在Servlet中调用。然后创建一个Servlet类,该类用于接收GET请求传递的4个参数,调用SignUtil工具类中封装的checkSignature()方法进行请求校验,若校验成功,将接收到的参数echostr原样返回。
[0036] 上述Servlet类的doPost()方法中完成了消息的接收与响应,其中还缺乏一个很重要的消息处理工具类MessageUtil,该类主要包含了解析请求消息和响应消息对象转XML中涉及的方法。在MessageUtil类中定义了一系列成员变量,包括请求消息类型(文本、图片、语音、视频、地理位置、链接和事件推送)、事件类型(订阅、取消订阅、扫描带参数二维码、上报地理位置和自定义菜单)和响应消息类型(文本、图片、语音、视频、音乐和图文)。
[0037] 以学号为2016666666666的读者借阅情况查询为例,在微信上查询,首次需发送“B#2016666666666&123456”指令(学号和密码)绑定学号。当绑定成功后,发送“borrow”借阅查询指令,则收到借阅书目信息。
[0038] 以学号为2016666666666的读者借出情况查询为例,在微信上查询,发送“loan”指令(需在已绑定学号的情况下),则收到借出书目信息,该书目信息与在应用系统中查询结果是一致的,满足了读者对信息快速查询的需求。
[0039] 公众账号服务器通过网上书店畅销排行榜定期为用户推荐热门书籍,例如当当网、京东、亚逊等网上书店,统计畅销排行榜,省去读者寻找书籍的时间。采用基于标签的协同过滤推荐算法为所述用户推荐书籍,包括以下步骤:
[0040] 将用户-标签-书籍三维关系分解为用户-标签、标签-书籍2个二维关系,在用户-标签关系中计算用户对标签标注频率和标签对用户的逆向频率,在标签与书籍关系中计算标签对书籍标注频率和频率对标签的逆向频率;
[0041] 构建用户对资源的兴趣模型,分别计算用户与标签的关联度、书籍与标签的关联度,再计算用户对书籍的兴趣;
[0042] 计算书籍的相似度,根据不同书籍被同一标签标注的次数评估书籍之间的相似度,采用Jaccard系数计算得到书籍的相似度;
[0043] 预测目标用户对待推荐新书籍的兴趣度,根据构建的用户对书籍的兴趣模型,以及待推荐新资源与已标注书籍的相似度计算得到目标用户对新书籍的兴趣度;
[0044] 将目标用户对于新书籍的预测兴趣度按照从大到小排序,取出排名靠前的书籍作为最终推荐集并输出。
[0045] 本发明为了实现书屋业务嵌入微信应用,并降低程序的开发难度,选择JavaServlet环境,并基于开源SDK控件进行开发;选择Eclipse开源工具,使用开源框架Dom4j和XStream来实现XML消息的解析与封装等工作。
[0046] 本发明基于JavaWeb微信公众平台下的个性化书屋的设计与实现,系统地介绍了设计思路、具体设计和最终实现效果。本发明还可进一步优化,利用网络爬虫,获取互联网庞大数据进行分析后,给予读者推荐书籍,同时扩展和推荐好友的功能,并利用学校组织者身份对公众号进行认证(帐号主体为个人时,无法开通微信认证),增加自定义菜单权限,将查询指令方式转换为菜单向导方式,从而提升用户应用体验,为用户提供更多便捷服务。
[0047] 尽管本发明的实施方案已公开如上,但其并不仅仅限于说明书和实施方式中所列运用,它完全可以被适用于各种适合本发明的领域,对于熟悉本领域的人员而言,可容易地实现另外的修改,因此在不背离权利要求及等同范围所限定的一般概念下,本发明并不限于特定的细节和这里示出与描述的图例。
高效检索全球专利

专利汇是专利免费检索,专利查询,专利分析-国家发明专利查询检索分析平台,是提供专利分析,专利查询,专利检索等数据服务功能的知识产权数据服务商。

我们的产品包含105个国家的1.26亿组数据,免费查、免费专利分析。

申请试用

分析报告

专利汇分析报告产品可以对行业情报数据进行梳理分析,涉及维度包括行业专利基本状况分析、地域分析、技术分析、发明人分析、申请人分析、专利权人分析、失效分析、核心专利分析、法律分析、研发重点分析、企业专利处境分析、技术处境分析、专利寿命分析、企业定位分析、引证分析等超过60个分析角度,系统通过AI智能系统对图表进行解读,只需1分钟,一键生成行业专利分析报告。

申请试用

QQ群二维码
意见反馈