溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

微信小程序中GoEasy實(shí)現(xiàn)websocket實(shí)時通訊的方法

發(fā)布時間:2020-07-23 14:33:23 來源:億速云 閱讀:179 作者:小豬 欄目:web開發(fā)

這篇文章主要講解了微信小程序中GoEasy實(shí)現(xiàn)websocket實(shí)時通訊的方法,內(nèi)容清晰明了,對此有興趣的小伙伴可以學(xué)習(xí)一下,相信大家閱讀完之后會有幫助。

不需要下載安裝,便可以在微信好友、微信群之間快速的轉(zhuǎn)發(fā),用戶只需要掃碼或者在微信里點(diǎn)擊,就可以立即運(yùn)行,有著近似APP的用戶體驗(yàn),使得微信小程序成為全民熱愛的好東西~

同時因?yàn)槲⑿判〕绦蚴褂玫氖荍avascript語法,對前端開發(fā)人員而言,幾乎是沒有學(xué)習(xí)成本和技術(shù)門檻的。對于大部分場景,都可以使用小程序快速開發(fā)實(shí)現(xiàn),不論是開發(fā)周期還是開發(fā)成本都低的讓人笑哭,所以受到了技術(shù)開發(fā)團(tuán)隊的各種追捧~

但如果要在小程序里快速的實(shí)現(xiàn)一個即時通訊功能,就有點(diǎn)尷尬,因?yàn)槲⑿殴俜教峁┑闹皇且粋€底層的websocket api,要在項目中直接使用,還需要做很多額外的工作,比如首先就需要搭建自己的websocket服務(wù)~

那有沒有簡單的方式呢? 當(dāng)然是有的!

今天小編就手把手的教您用GoEasy在微信小程序里,最短的時間快速實(shí)現(xiàn)一個websocket即時通訊Demo。

微信小程序中GoEasy實(shí)現(xiàn)websocket實(shí)時通訊的方法

本demo已經(jīng)完成了真機(jī)下的小程序的測試,完整源代碼開源到oschina的碼云上,clone后,只需要將代碼里的appkey換成自己的common key,就可以體驗(yàn)了, 源碼網(wǎng)址:https://gitee.com/goeasy-io/GoEasyDemo-wxapp-Helloworld

1、獲取appkey

GoEasy官網(wǎng)上注冊賬號,創(chuàng)建一個應(yīng)用,拿到您的appkey。

微信小程序中GoEasy實(shí)現(xiàn)websocket實(shí)時通訊的方法

GoEasy提供了兩種類型的appkey:

  • Common key: 即可以接收消息,也可以發(fā)送消息,與Subscribe Key最大的區(qū)別就是有寫權(quán)限,可以發(fā)消息。適用于有消息發(fā)送需求的客戶端和服務(wù)端開發(fā)。
  • Subscribe key: 只能接收消息,不可以發(fā)送消息,與Common Key最大的區(qū)別就是沒有寫權(quán)限,只能收消息。可以用于一些沒有發(fā)送需求的客戶端。

2、獲取GoEasy SDK

下載https://cdn.goeasy.io/download/goeasy-1.0.11.js

import GoEasy from './goeasy-1.0.11';

3、初始化GoEasy對象

var self = this;
this.goeasy = GoEasy({
 host: 'hangzhou.goeasy.io',
 appkey: "您的appkey",
 onConnected: function () {
  console.log("GoEasy connect successfully.");
  self.unshiftMessage("連接成功.");
 },
 onDisconnected: function () {
  console.log("GoEasy disconnected.")
  self.unshiftMessage("連接已斷開.");
 },
 onConnectFailed: function (error) {
  console.log(error);
  self.unshiftMessage("連接失敗,請檢查您的appkey和host配置");
 }
})

根據(jù)您在GoEasy后臺創(chuàng)建應(yīng)用時選擇的區(qū)域,來傳入不同的Host,如果您創(chuàng)建GoEasy應(yīng)用時,選擇了杭州,那么host:"hangzhou.goeasy.io"。選擇了新加坡,host:"singapore.goeasy.io"。

如果您的大部分用戶都是在國內(nèi),創(chuàng)建應(yīng)用時,記得選擇杭州,以便獲得更快的通訊速度。

4、小程序端接收消息

var self = this;
this.goeasy.subscribe({
 channel: "my_channel",
 onMessage: function (message) {
  self.unshiftMessage(message.content);
 },
 onSuccess: function () {
  self.unshiftMessage('訂閱成功.');
 }
});

很多朋友會問channel從哪里來,如何創(chuàng)建,應(yīng)該傳入什么呢?

根據(jù)您的業(yè)務(wù)需求來設(shè)定,channel可以為任意字符串,除了不能包含空格,和不建議使用中文外,沒有任何限制,只需要和消息的發(fā)送端保持一致,就可以收到消息。channel可以是您直播間的uuid,也可以是一個用戶的唯一表示符,可以任意定義,channel不需要創(chuàng)建,可以隨用隨棄。

5、小程序端發(fā)送消息:

發(fā)送時,需要注意channel一定要和subscribe的channel完全一致,否則無法收到。

this.goeasy.publish({
 channel: "my_channel",
 message: self.data.message,
 onSuccess: function () {
  self.setData({
   message: ''
  }); //清空發(fā)送消息內(nèi)容
  console.log("send message success");
 },
 onFailed: function (error) {
  self.unshiftMessage('發(fā)送失敗,請檢查您的appkey和host配置.');
 }
});

本代碼源碼下載:https://gitee.com/goeasy-io/GoEasyDemo-wxapp-Helloworld

特別強(qiáng)調(diào):

在運(yùn)行之前,一定要在微信公眾號平臺配置socket合法域名,否則無法建立連接。具體步驟:
訪問mp.weixin.qq.com,進(jìn)入微信公眾平臺|小程序 -> 設(shè)置 -> 開發(fā)設(shè)置 -> 服務(wù)器域名
socket合法域名-> 添加GoEasy的地址: wx-hangzhou.goeasy.io(記得wx-開頭)
若您創(chuàng)建GoEasy應(yīng)用時選擇了新加坡區(qū)域則添加地址:wx-singapore.goeasy.io

答疑時間:

1、我的服務(wù)器端可以給小程序發(fā)送消息嗎?都支持些哪些語言?

當(dāng)然可以,任何語言都可以通過調(diào)用GoEasy的Rest API發(fā)送消息,同時為了大家方便,GoEasy的官方文檔里,也準(zhǔn)備了Java, C#,NodeJS,PHP,Ruby和Python等常見語言調(diào)用REST API的代碼。

2、GoEasy可以發(fā)送圖片,語音和視頻嗎?

當(dāng)然可以,您可以通過推送文件路徑的方式來實(shí)現(xiàn)文件的發(fā)送。按照行業(yè)慣例,不論MSN,微信,QQ對于圖片和視頻,通常的做法都是,只推送文件路徑,而不會推送文件本身。你如果有注意的話,當(dāng)您接受圖片和視頻的時候,收到消息后,等一會兒才能看,就是因?yàn)榘l(fā)送的時候,只發(fā)送了路徑。

3、GoEasy和微信小程序官方的websocket API有什么區(qū)別和優(yōu)勢?

小程序官方的websocket API主要是用來與您的websocket服務(wù)通訊,所以使用小程序websocket的前提是,首先要搭建好您自己的websocket服務(wù),然后與之通訊。這是一個純技術(shù)的API,在建立網(wǎng)絡(luò)連接后,還有很多的工作需要自己來完成,比如:

  • 需要自己實(shí)現(xiàn)心跳機(jī)制,來維護(hù)網(wǎng)絡(luò)連接,來判斷客戶端的網(wǎng)絡(luò)連接狀態(tài);
  • 需要自己實(shí)現(xiàn)斷網(wǎng)自動重連;需要自己維護(hù)消息列表,確保遇到斷網(wǎng)重連后,消息能夠補(bǔ)發(fā);
  • 需要自己維護(hù)一個客戶端列表;
  • 等等很多細(xì)致而繁雜的工作,比如websocket的安全機(jī)制和性能優(yōu)化;

此之外服務(wù)端也有很多工作需要自己完成,有興趣自己搭建websocket的話,可以參考這篇技術(shù)分享《搭建websocket消息推送服務(wù),必須要考慮的幾個問題》

而GoEasy是一個成熟穩(wěn)定的企業(yè)級websocket PAAS服務(wù)平臺,開發(fā)人員不需要考慮websocket服務(wù)端的搭建,只需要幾行代碼,就可以輕松實(shí)現(xiàn)客戶端與客戶端之間,服務(wù)器與客戶端之間的的websocket通信,不需要考慮性能,安全,高可用集群的問題,只需要全力專注于開發(fā)自己的業(yè)務(wù)功能就好了。

GoEasy已經(jīng)內(nèi)置websocket中必備的心跳,斷網(wǎng)重連,消息補(bǔ)發(fā),歷史消息和客戶端上下線提醒等特性,開發(fā)人員也不需要自己搭建websocket服務(wù)處理集群高可用,安全和性能問題。GoEasy已經(jīng)穩(wěn)定運(yùn)行了5年,支持千萬級并發(fā),成功支撐過很多知名企業(yè)的重要活動,安全性和可靠性都是久經(jīng)考驗(yàn)。

4、GoEasy在小程序的開發(fā)中主要用在那些場景呢?

從應(yīng)用場景上來說,所有需要websocket通信的場景,GoEasy都可以完美支持:

  • 聊天,IM,直播彈幕,用戶上下線提醒, 在線用戶列表
  • 掃碼點(diǎn)菜,掃碼登錄, 掃碼支付, 掃碼簽到, 掃碼打印
  • 事件提醒,工單,訂單實(shí)時提醒
  • 在線拍賣, 在線點(diǎn)餐,在線選座 實(shí)時數(shù)據(jù)展示,實(shí)時監(jiān)控大屏, 金融實(shí)時行情顯示,設(shè)備監(jiān)控系統(tǒng)
  • 實(shí)時位置跟蹤,外賣實(shí)時跟蹤,物流實(shí)時跟蹤
  • 遠(yuǎn)程畫板,遠(yuǎn)程醫(yī)療,游戲,遠(yuǎn)程在線授課

5、GoEasy的文檔為什么這么簡單?簡單到我都不知道如何使用

簡單還不好嗎?GoEasy從研發(fā)的第一天,就把追求API的極簡作為我們的工作重點(diǎn)。嚴(yán)格控制接口的數(shù)量,就是是為了降低開發(fā)人員的學(xué)習(xí)成本,其實(shí)就是為了讓您爽??!但這并不影響GoEasy完美支持所有的websocket即時通訊需求。

看完上述內(nèi)容,是不是對微信小程序中GoEasy實(shí)現(xiàn)websocket實(shí)時通訊的方法有進(jìn)一步的了解,如果還想學(xué)習(xí)更多內(nèi)容,歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI