redis,nodejs,php,pub/sub 实战: 微信语音识别

简介: 2015年5月22日 20:20:20 星期五 效果: 这边对微信说话,  浏览器端及时显示语音识别的文字 注意: 在连接socket.io时, 按下浏览器f12, 如果一直有请求不断的刷, 说明socket.

2015年5月22日 20:20:20 星期五

效果:

这边对微信说话,  浏览器端及时显示语音识别的文字

注意:

在连接socket.io时, 按下浏览器f12, 如果一直有请求不断的刷, 说明socket.io没有连接成功

代码:

node.js server端

 1 var module_path = '/usr/local/web/node/bin/node_modules/';
 2 var html = '<html> <head> <meta charset="utf-8"> <title>微信接口</title> <script src="http://cdn.bootcss.com/jquery/2.1.4/jquery.js"></script> <script src="http://cdn.bootcss.com/socket.io/1.3.5/socket.io.js"></script> </head> <body> <div id="voice"> 语音识别:<br><br> </div> <script type="text/javascript"> var voice = document.getElementById("voice"); var socket = io.connect("http://www.zhangzhibin.com:1337"); socket.on("hello", function(data){console.log(data); socket.emit("hello", {"status":"ok"}); }); socket.on("emit", function(data){var t = data+"<br>"; voice.innerHTML += t; socket.emit("emit", {"get":"data"}); }); </script> </body> </html>';
 3 //链接redis 
 4 var redis = require(module_path+'redis');
 5 var redis_client = redis.createClient(6379, '127.0.0.1');
 6 redis_client.auth('123456');
 7 redis_client.on('error', function(error){
 8     console.log('redis-error: ' + error);
 9 });
10 
11 //创建服务器
12 var http = require('http');
13 var url = require('url');
14 var fs = require('fs');
15 var ch = false;
16 var server = http.createServer(function (req, res) {
17     //获取请求参数
18     var objReqArg = url.parse(req.url, true).query;
19     ch = objReqArg.openid;
20     if (ch) {
21         redis_client.subscribe(ch, function(e){
22             console.log('channel: '+ ch);
23         });
24     };
25     //返回
26     res.writeHead(200, {'Content-Type': 'text/html'});
27     res.end(html);
28     
29 });
30 server.listen(1337, 'www.zhangzhibin.com');
31 
32 //创建服务器
33 var io = require(module_path + 'socket.io').listen(server);
34 io.sockets.on('connection', function(socket){
35     socket.on('hello', function(data){
36         console.log(data);
37     });
38     socket.emit('hello', function(data){
39         console.log(data);
40     });
41     redis_client.on('message', function(error, msg){
42         socket.emit('emit', msg);
43     });
44 });
45 
46 console.log('Server running at http://www.zhangzhibin.com:1337');

浏览器端html代码:

就是上边代码的第二行变量 var html='....'

 1 <html> 
 2     <head> 
 3         <meta charset="utf-8"> 
 4         <title>微信接口</title> 
 5         <script src="http://cdn.bootcss.com/jquery/2.1.4/jquery.js"></script> 
 6         <script src="http://cdn.bootcss.com/socket.io/1.3.5/socket.io.js"></script> 
 7     </head> 
 8     <body> 
 9     <div id="voice"> 语音识别:<br><br> </div> 
10     <script type="text/javascript"> 
11         var voice = document.getElementById("voice"); 
12         var socket = io.connect("http://www.zhangzhibin.com:1337"); 
13         socket.on("hello", function(data){ console.log(data);  socket.emit("hello", {"status":"ok"}); }); 
14         socket.on("emit", function(data){ var t = data+"<br>"; voice.innerHTML += t; socket.emit("emit", {"get":"data"}); }); 
15     </script> 
16     </body> 
17 </html>

微信端:

注意一点, 在语音回调函数中, 将语音识别的结果publish到某一个频道上即可

这时, 会触发上边第41行代码, 将文字发完浏览器端

下边是微信回调的代码:

 1     public function voice()
 2     {
 3         // 每次发送消息都会post 来一份签名相关的数据
 4         // $echostr = $this->checkSignature();
 5         // exit($echostr);
 6 
 7         preg_match('#<FromUserName><!\[CDATA\[([a-zA-Z0-9_]+)\]#', $GLOBALS['HTTP_RAW_POST_DATA'], $matches1);
 8         preg_match('#<Recognition><!\[CDATA\[([^\]]*)\]#', $GLOBALS['HTTP_RAW_POST_DATA'], $matches2);
 9         $openid = !empty($matches1[1]) ? $matches1[1] : '0';
10         $text = !empty($matches2[1]) ? $matches2[1] : '没听清...';
11 
12         $objRedis = iredis::getInstance();
13         $objRedis->publish($openid, $text);
14 
15     }

 

测试方法:

1. 关注我的微信公众号"xxx"

2. 发送消息"主播_username"

3. pc端打开 http://www.zhangzhibin.com/wechat/index/zhubolist

4. 点击你刚才输入的用户名, 进入你的对话页面

5. 对微信发送语音消息, 即可在刚才的浏览器页面看到语音识别结果

 

冷知识点:

php流处理

$_POST 无法解释二进制流,需要用到 $GLOBALS['HTTP_RAW_POST_DATA'] 或 php://input 

$content = $GLOBALS['HTTP_RAW_POST_DATA'];  // 需要php.ini设置

$content = file_get_contents('php://input'); // 不需要php.ini设置,内存压力小

目录
相关文章
|
7月前
|
缓存 大数据 PHP
PHP性能优化实战:告别缓慢脚本
PHP性能优化实战:告别缓慢脚本
266 89
|
7月前
|
安全 PHP
PHP 8 新特性实战:提升开发效率的利器
PHP 8 新特性实战:提升开发效率的利器
227 87
|
7月前
|
SQL 缓存 大数据
PHP性能优化实战:4个立竿见影的技巧
PHP性能优化实战:4个立竿见影的技巧
251 88
|
7月前
|
安全 PHP
PHP 8 新特性实战:提升开发效率的利器
PHP 8 新特性实战:提升开发效率的利器
248 88
|
8月前
|
API PHP
PHP 8新特性:Match表达式与联合类型实战指南
PHP 8新特性:Match表达式与联合类型实战指南
|
5月前
|
存储 NoSQL 前端开发
Redis专题-实战篇一-基于Session和Redis实现登录业务
本项目基于SpringBoot实现黑马点评系统,涵盖Session与Redis两种登录方案。通过验证码登录、用户信息存储、拦截器校验等流程,解决集群环境下Session不共享问题,采用Redis替代Session实现数据共享与自动续期,提升系统可扩展性与安全性。
351 3
Redis专题-实战篇一-基于Session和Redis实现登录业务
|
5月前
|
存储 缓存 NoSQL
Redis专题-实战篇二-商户查询缓存
本文介绍了缓存的基本概念、应用场景及实现方式,涵盖Redis缓存设计、缓存更新策略、缓存穿透问题及其解决方案。重点讲解了缓存空对象与布隆过滤器的使用,并通过代码示例演示了商铺查询的缓存优化实践。
272 1
Redis专题-实战篇二-商户查询缓存
|
11月前
|
数据采集 存储 数据可视化
分布式爬虫框架Scrapy-Redis实战指南
本文介绍如何使用Scrapy-Redis构建分布式爬虫系统,采集携程平台上热门城市的酒店价格与评价信息。通过代理IP、Cookie和User-Agent设置规避反爬策略,实现高效数据抓取。结合价格动态趋势分析,助力酒店业优化市场策略、提升服务质量。技术架构涵盖Scrapy-Redis核心调度、代理中间件及数据解析存储,提供完整的技术路线图与代码示例。
1188 0
分布式爬虫框架Scrapy-Redis实战指南
|
7月前
|
安全 大数据 PHP
PHP 7+ 新特性实战指南:提升开发效率
PHP 7+ 新特性实战指南:提升开发效率
234 87
|
5月前
|
消息中间件 人工智能 Java
抖音微信爆款小游戏大全:免费休闲/竞技/益智/PHP+Java全筏开源开发
本文基于2025年最新行业数据,深入解析抖音/微信爆款小游戏的开发逻辑,重点讲解PHP+Java双引擎架构实战,涵盖技术选型、架构设计、性能优化与开源生态,提供完整开源工具链,助力开发者从理论到落地打造高留存、高并发的小游戏产品。