内射老阿姨1区2区3区4区_久久精品人人做人人爽电影蜜月_久久国产精品亚洲77777_99精品又大又爽又粗少妇毛片

node如何實(shí)現(xiàn)語(yǔ)音聊天

本篇內(nèi)容主要講解“node如何實(shí)現(xiàn)語(yǔ)音聊天”,感興趣的朋友不妨來(lái)看看。本文介紹的方法操作簡(jiǎn)單快捷,實(shí)用性強(qiáng)。下面就讓小編來(lái)帶大家學(xué)習(xí)“node如何實(shí)現(xiàn)語(yǔ)音聊天”吧!

成都創(chuàng)新互聯(lián)公司主要從事網(wǎng)站設(shè)計(jì)制作、做網(wǎng)站、網(wǎng)頁(yè)設(shè)計(jì)、企業(yè)做網(wǎng)站、公司建網(wǎng)站等業(yè)務(wù)。立足成都服務(wù)涇源,10余年網(wǎng)站建設(shè)經(jīng)驗(yàn),價(jià)格優(yōu)惠、服務(wù)專(zhuān)業(yè),歡迎來(lái)電咨詢(xún)建站服務(wù):028-86922220

node實(shí)現(xiàn)語(yǔ)音聊天的方法:1、使用nodejs模塊express創(chuàng)建一個(gè)web服務(wù)器;2、創(chuàng)建https連接;3、通過(guò)“socket.io”實(shí)現(xiàn)客戶(hù)端與服務(wù)端實(shí)時(shí)通信即可。

基于nodejs的語(yǔ)音聊天

node如何實(shí)現(xiàn)語(yǔ)音聊天

描述

程序在 iamshaunjp 的群聊功能基礎(chǔ)上利用webRTC技術(shù),添加了語(yǔ)音群聊功能,在其他人鍵盤(pán)輸入時(shí),會(huì)出現(xiàn)類(lèi)似微信的對(duì)方正在輸入字樣。

使用的nodejs模塊

  • express:創(chuàng)建一個(gè)web服務(wù)器

  • https:創(chuàng)建https連接(局域網(wǎng)或者外網(wǎng)webRTC需要https連接,具體見(jiàn)tutoril)

  • socket.io:客戶(hù)端與服務(wù)端實(shí)時(shí)通信

js文件

  • chat.js:實(shí)現(xiàn)按鈕事件的注冊(cè)、文本數(shù)據(jù)的發(fā)送等

  • record.js:實(shí)現(xiàn)語(yǔ)音消息的錄取、播放、發(fā)送等

結(jié)構(gòu)圖和流程圖

node如何實(shí)現(xiàn)語(yǔ)音聊天

node如何實(shí)現(xiàn)語(yǔ)音聊天

文本通信

詳情見(jiàn)public/js/chat.js注釋

發(fā)送數(shù)據(jù)

  • 進(jìn)入頁(yè)面進(jìn)行與服務(wù)器的socket連接

  • 客戶(hù)端輸入文本數(shù)據(jù)

  • 客戶(hù)點(diǎn)擊sent按鈕,觸發(fā)click事件,并產(chǎn)生chat事件準(zhǔn)備想服務(wù)器emit

  • soket連接發(fā)送給服務(wù)器chat事件和客戶(hù)端產(chǎn)生的數(shù)據(jù)

接收數(shù)據(jù)

  • socket接受到服務(wù)器發(fā)送來(lái)的data和服務(wù)器發(fā)送來(lái)的chat事件

  • 提取data文本

  • js在index.html添加文本數(shù)據(jù),完成接收數(shù)據(jù)并顯示

語(yǔ)音通信

詳情見(jiàn)public/js/record.js注釋

  • 接受和發(fā)送語(yǔ)音數(shù)據(jù)類(lèi)似與文本數(shù)據(jù)的通信

  • 利用webRTC獲取到用戶(hù)的視頻或者音頻轉(zhuǎn)換為blob格式數(shù)據(jù),并發(fā)送給服務(wù)器數(shù)據(jù)。

  • 接受消息時(shí),數(shù)據(jù)類(lèi)型是blob格式,對(duì)blob數(shù)據(jù)解析,利用html5的audio標(biāo)簽進(jìn)行播放

服務(wù)器轉(zhuǎn)發(fā)數(shù)據(jù)

客戶(hù)端發(fā)送給服務(wù)器數(shù)據(jù),服務(wù)器觸發(fā)chat事件,將客戶(hù)端發(fā)送來(lái)的數(shù)據(jù)以廣播的形式發(fā)送到每一個(gè)客戶(hù)端,完成群聊的功能。

創(chuàng)建https證書(shū)

在localhost中使用webRTC不需要使用https,但是在局域網(wǎng)或者外網(wǎng)使用webRTC,必須強(qiáng)制使用webRTC,這里采用自己生成證書(shū)供測(cè)試使用,具體生成方法和設(shè)置https方法參考博客:

  • 生成自己簽名的證書(shū)(有效期365天)

 openssl req -x509 -newkey rsa:2048 -keyout key.pem -out cert.pem -days 365
  • 使用https連接的express,例子如下:

  var fs = require('fs'),
   https = require('https'),
   express = require('express'),
   app = express();

   https.createServer({
     key: fs.readFileSync('key.pem'),
     cert: fs.readFileSync('cert.pem')
   }, app).listen(55555);

   app.get('/', function (req, res) {
     res.header('Content-type', 'text/html');
     return res.end('<h2>Hello, Secure World!</h2>');
   });

到此,相信大家對(duì)“node如何實(shí)現(xiàn)語(yǔ)音聊天”有了更深的了解,不妨來(lái)實(shí)際操作一番吧!這里是創(chuàng)新互聯(lián)網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢(xún),關(guān)注我們,繼續(xù)學(xué)習(xí)!

文章題目:node如何實(shí)現(xiàn)語(yǔ)音聊天
網(wǎng)頁(yè)地址:http://m.rwnh.cn/article16/jejcdg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站內(nèi)鏈、品牌網(wǎng)站制作、自適應(yīng)網(wǎng)站、外貿(mào)建站、軟件開(kāi)發(fā)、企業(yè)網(wǎng)站制作

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話(huà):028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

微信小程序開(kāi)發(fā)
游戏| 陇川县| 襄汾县| 改则县| 双江| 双柏县| 武鸣县| 韶山市| 定边县| 曲靖市| 化德县| 尉氏县| 巫山县| 南漳县| 襄汾县| 华安县| 阳信县| 洪洞县| 东乡| 云霄县| 奎屯市| 五指山市| 新蔡县| 靖西县| 比如县| 秭归县| 响水县| 小金县| 伽师县| 昆明市| 蓝山县| 土默特右旗| 吉林市| 大英县| 新野县| 隆昌县| 蓝田县| 醴陵市| 崇明县| 赣州市| 靖边县|