微信快速开发框架(八)-- V2.3--增加语音识别及网页获取用户信息,代码已更新至Github

简介: 不知不觉,版本以每周更新一次的脚步进行着,接下来应该是重构我的代码及框架的结构,有朋友反应代码有点乱,确实如此,当时写的时候只是按照订阅号来写的,后来才慢慢增加到支持API接口。目前还在开发第三方微信平台,旨在使用户能够无需自己开发就能简易搭建微信平台。

不知不觉,版本以每周更新一次的脚步进行着,接下来应该是重构我的代码及框架的结构,有朋友反应代码有点乱,确实如此,当时写的时候只是按照订阅号来写的,后来才慢慢增加到支持API接口。目前还在开发第三方微信平台,旨在使用户能够无需自己开发就能简易搭建微信平台。

更新内容

1、增加支持语音识别

2、增加“网页授权获取用户基本信息

语音识别其实是对Voice信息的一个扩展,您必须启用语音识别功能,启用后会在VoiceMessage中增加一个Recongnition字段,我们可以判断这个字段的内容进行响应。因为其实对Voice的一个扩展,此次更新在VoiceMessageRequest中加入了Recongnition字段。

在“网页授权获取用户基本信息”中,我使用的是测试账号,但发现了bug,我不知道只存在于测试账号还是正式账号也存在bug,目前我只有未认证的服务号可以测试,等下个月认证后我会测试下的。bug将在后面介绍。

此次内容的测试,我使用的是申请的测试号,大家可以自行申请,也可以加入我的测试号:

image因测试号仅支持20个粉丝,请亲测试后,自觉取消关注,方便其他用户测试

测试一:语音识别

在先前的框架介绍中,我使用了框架然后获取博客园首页文章,在此基础上,我改变了下,我只要发送的语音中含有博客园就让其响应相同结果。

首先,创建一个VoiceMessageRole实现IMessageRole:

public class VoiceMessageRole : IMessageRole
    {
        public IMessageHandler MessageRole(MiddleMessage message)
        {
            var request = message.RequestMessage as RequestVoiceMessage;
            if (request != null)
            {
                //sMyLog.Log("语音识别:" + request.Recognition);
                if (!String.IsNullOrEmpty(request.Recognition))
                {
                    if (request.Recognition.IndexOf("博客园文章") > -1)
                    {
                        return new CnblogsArticleNewsMessageHandler();
                    }

                    if (request.Recognition.IndexOf("博客园") > -1)
                    {
                        return new CnblogsTextMessageHandler();
                    }

                    return new DefaultMessageHandler();
                }
                else
                {
                    return new VoiceMessageHandler();
                }
            }
            else
            {
                return new DefaultMessageHandler();
            }
        }
    }

 

 

规则的话可以自己定义,我这里就不重复造轮子了。在【MsgTypeMessageRole】规则中,增加对Voice的规则判断,使其进入到VoiceMessageRole规则。

接下来看下结果:

image 语音一:博客园

image 语音二:博客园文章

测试二:网页授权获取用户信息

通过文档,我们知道在使用网页授权这里,会使用OAuth2来完成授权的,文档中介绍如果使用Scope为Snsapi_userinfo可以不关注也能通过网页授权获取用户信息,经测试无效,必须为关注用户才能获取。网页授权用户信息步骤如下:

第一步:设置回调域名,测试账号在

image

进行修改,网页授权的域名仅对设置的域名有效,其下级域名都无效

image

第二步:用户同意授权,获取Code

这里我们就是生成一个链接,用户使用手机微信进入后,就能获取Code,链接是自己创建的,为了方便,我在框架中加了一个OAuthHelper类,您可以快速创建相应链接,使用方式如下:

new OAuthHelper(string appId).BuildOAuthUrl(string redirectUrl, OAuthScope scope, string state);

 

 

 

这个只是辅助类,您也可以自己写一个

根据OAuthScope的不同,显示也不同,Base方式下会直接跳转到redirectUrl,userinfo方式下会显示授权页面,点击同意后会跳转到redirecturl。

第三步:获取AccessToken和OpenId

Code可以通过Request[“Code”]获取,获取后,通过以下方式获取AccessToken和OpenId:

var request = new SnsOAuthAccessTokenRequest
            {
                AppID = m_appIdent.AppID,
                AppSecret = m_appIdent.AppSecret,
                Code = Label1.Text
            };
            var response = m_client.Execute(request);

response为SnsOAuthAccessTokenResponse类型,包含以下属性:

image

第四步:通过AccessToken获取用户信息:

SnsUserInfoRequest request = new SnsUserInfoRequest
            {
                OAuthToken = accesstoken,
Lang =
Language.CN, OpenId = OpenId }; SnsUserInfoResponse response = m_client.Execute(request);

这里要注意的是OAuthToken为第三步获取的Token,并非之前我们用的AccessToken。

SnsUserInfoResponse包含了如下用户信息:

image

至此,获取用户信息结束。

网页授权获取用户信息BUG

这个Bug我不知道是不是只在测试账号中出现,因为我没有正式账号,所以无法下判断。Bug如下:

1、Scope为Snsapi_Base时,也能获取用户基本信息(第四步),但在文档中说明是Base情况下是无法获取用户信息,只能获取到OpenId。

2、Scope为Snsapi_UserInfo时,必须为关注用户,但在文档中介绍,没有关注的用户在弹出授权窗口授权后也能进行浏览及获取用户信息。

以上Bug已提交至微信,但还未回复,或许会更近。

实战测试

请先加我的测试账号,然后使用微信扫一扫功能,扫描二维码:

image                image

      (Snsapi_Base)                             (Snsapi_Userinfo)

扫描后会转到相应链接,您可以点击“获取AccessToken”,“刷新AccessToken”和“获取用户信息”进行测试。结果截图如下:

image

 

 

 

写在最后

自从发布了微信快速开发框架以来,收到了很多朋友的关注,也在得到反馈后逐步的改善。在和朋友的探讨中,发觉在微信公众平台的开发中,难得不是开发,而且微信平台对接口的一些限制,我们只有到了认证的服务号后才能使用完全的高级接口,对于很多朋友来说,基本上都是认证过的订阅号,所以很多测试都无法进行,希望后续微信平台会放宽限制。

明天去坐邮轮去台湾了,大家以后想旅游,做签证之类都可以找我,可以加我私信:jamesying1,不定期会发些特价旅游线路。作为码农,必要的放松还是需要的,大家不要太累,身体是革命的本钱。

相关实践学习
达摩院智能语音交互 - 声纹识别技术
声纹识别是基于每个发音人的发音器官构造不同,识别当前发音人的身份。按照任务具体分为两种: 声纹辨认:从说话人集合中判别出测试语音所属的说话人,为多选一的问题 声纹确认:判断测试语音是否由目标说话人所说,是二选一的问题(是或者不是) 按照应用具体分为两种: 文本相关:要求使用者重复指定的话语,通常包含与训练信息相同的文本(精度较高,适合当前应用模式) 文本无关:对使用者发音内容和语言没有要求,受信道环境影响比较大,精度不高 本课程主要介绍声纹识别的原型技术、系统架构及应用案例等。 讲师介绍: 郑斯奇,达摩院算法专家,毕业于美国哈佛大学,研究方向包括声纹识别、性别、年龄、语种识别等。致力于推动端侧声纹与个性化技术的研究和大规模应用。
相关文章
|
8月前
|
Rust 安全 前端开发
Github 轻松斩获30k+ Star,桌面应用开发太丝滑啦,Tauri框架能重塑桌面App开发?别错过,抓紧上车
Tauri 是一个基于 Rust 的开源框架,用于构建轻量级、高性能、安全的跨平台桌面及移动应用。它利用系统 WebView 渲染前端界面,后端由 Rust 编写,具备出色的性能和安全性。相比 Electron,Tauri 应用体积更小、启动更快,且默认权限更安全。它支持 React、Vue、Svelte 等主流前端框架,并提供自动更新、CLI 工具链、资源注入优化等功能,适用于生产力工具、开发者工具、数据分析、AI 应用等多种场景。目前 Tauri 在 GitHub 上已获得超过 30,000 Star,社区活跃,是现代桌面应用开发的理想选择。
994 0
|
6月前
|
消息中间件 人工智能 Java
抖音微信爆款小游戏大全:免费休闲/竞技/益智/PHP+Java全筏开源开发
本文基于2025年最新行业数据,深入解析抖音/微信爆款小游戏的开发逻辑,重点讲解PHP+Java双引擎架构实战,涵盖技术选型、架构设计、性能优化与开源生态,提供完整开源工具链,助力开发者从理论到落地打造高留存、高并发的小游戏产品。
|
7月前
|
小程序 JavaScript API
uni-halo + 微信小程序开发实录:我的第一个作品诞生记
这篇文章介绍了使用uni-halo框架进行微信小程序开发的过程,包括选择该框架的原因、开发目标以及项目配置和部署的步骤。
369 0
uni-halo + 微信小程序开发实录:我的第一个作品诞生记
|
10月前
|
小程序 前端开发 Android开发
小程序微信分享功能如何开发?开放平台已绑定仍不能使用的问题?-优雅草卓伊凡
小程序微信分享功能如何开发?开放平台已绑定仍不能使用的问题?-优雅草卓伊凡
1968 29
小程序微信分享功能如何开发?开放平台已绑定仍不能使用的问题?-优雅草卓伊凡
|
7月前
|
人工智能 自然语言处理 JavaScript
Github又一AI黑科技项目,打造全栈架构,只需一个统一框架?
Motia 是一款现代化后端框架,融合 API 接口、后台任务、事件系统与 AI Agent,支持 JavaScript、TypeScript、Python 多语言协同开发。它提供可视化 Workbench、自动观测追踪、零配置部署等功能,帮助开发者高效构建事件驱动的工作流,显著降低部署与运维成本,提升 AI 项目落地效率。
636 0
|
8月前
|
前端开发 数据可视化 JavaScript
惊喜! Github 10k+ star 的国产流程图框架,LogicFlow 能解你的图编辑痛点?
LogicFlow 是一款高效、灵活的流程图编辑框架,支持可视化渲染、自定义节点、插件扩展及前端执行。适用于审批流、ER 图、低代码平台等多种场景,具备清晰架构与活跃社区,助力开发者快速实现专业流程图编辑与执行。
1353 1
|
9月前
|
监控 数据可视化 数据处理
微信养号脚本,全自动插件,AUTOJS开发版
这是一套自动化微信养号工具,包含主脚本`wechat_auto.js`与配置文件`config.json`。主脚本实现自动浏览朋友圈、随机阅读订阅号文章及搜索指定公众号三大功能,支持自定义滚动次数、阅读时长等参数。代码通过随机化操作间隔模拟真实用户行为,具备完善的错误处理和日志记录功能。配套UI模块提供可视化操作界面,可实时监控任务状态与运行日志,便于调整参数设置。控制器部分扩展了批量数据处理能力,如学生信息的增删改查操作,适用于多场景应用。下载地址:https://www.pan38.com/share.php?code=n6cPZ 提取码:8888(仅供学习参考)。
|
自然语言处理 搜索推荐 小程序
微信公众号接口:解锁公众号开发的无限可能
微信公众号接口是微信官方提供的API,支持开发者通过编程与公众号交互,实现自动回复、消息管理、用户管理和数据分析等功能。本文深入探讨接口的定义、类型、优势及应用场景,如智能客服、内容分发、电商闭环等,并介绍开发流程和工具,帮助运营者提升用户体验和效率。未来,随着微信生态的发展,公众号接口将带来更多机遇,如小程序融合、AI应用等。
|
JSON 小程序 JavaScript
uni-app开发微信小程序的报错[渲染层错误]排查及解决
uni-app开发微信小程序的报错[渲染层错误]排查及解决
3680 7
|
小程序 JavaScript 前端开发
uni-app开发微信小程序:四大解决方案,轻松应对主包与vendor.js过大打包难题
uni-app开发微信小程序:四大解决方案,轻松应对主包与vendor.js过大打包难题
3872 1

热门文章

最新文章