uniapp websocket

websocket 封裝

1. 將websocket.js放入任意文件夾中

let isSocketClose = false; // 是否關(guān)閉socket
let reconnectCount = 5; // 重連次數(shù)
let heartbeatInterval = ""; // 心跳定時器
let socketTask = null; // websocket對象

let againTimer = null; //斷線重連定時器


let url = null;
let onReFn = null;
let onSucFn = null;
let onErrFn = null;

/**
 * sockeUrl:websocet的地址
 * onReceive:消息監(jiān)聽的回調(diào)
 * onErrorEvent:拋出錯誤的回調(diào)枪萄,且彈窗連接失敗的提示框
 * onErrorSucceed:拋出成功回調(diào)问慎,主要用于隱藏連接失敗的提示框
 * */
const sokcet = (sockeUrl, onReceive, onErrorEvent, onErrorSucceed) => {
    url = sockeUrl;
    onReFn = onReceive;
    onErrFn = onErrorEvent;
    onSucFn = onErrorSucceed;
    isSocketClose = false;
    //判斷是否有websocet對象酌壕,有的話清空
    if (socketTask) {
        socketTask.close();
        socketTask = null;
        clearInterval(heartbeatInterval);
    }

    //WebSocket的地址
    // 【非常重要】必須確保你的服務(wù)器是成功的,如果是手機測試千萬別使用ws://127.0.0.1:9099【特別容易犯的錯誤】
    let url = sockeUrl
    // 連接
    socketTask = uni.connectSocket({
        url: url,
        success(data) {
            console.log("websocket連接成功");
            clearInterval(againTimer) //斷線重連定時器
        },
        fail: (err) => {
            console.log(url)
            console.log("報錯", err);
        }
    });

    // 連接打開
    socketTask.onOpen((res) => {
        console.log('WebSocket打開');
        clearInterval(againTimer) //斷線重連定時器
        onErrorSucceed({
            isShow: false
        }) // 用于提示框的隱藏
        heartbeatInterval && clearInterval(heartbeatInterval);
        // 10秒發(fā)送一次心跳
        heartbeatInterval = setInterval(() => {
            sendMsg('心跳ing')
        }, 1000 * 5)
    })
    // 監(jiān)聽連接失敗
    socketTask.onError((err) => {
        console.log('WebSocket連接打開失敗拼窥,請檢查', err);
        //停止發(fā)送心跳
        clearInterval(heartbeatInterval)
        //如果不是人為關(guān)閉的話汪诉,進(jìn)行重連
        if (!isSocketClose) {
            reconnect(url, onErrorEvent)
        }
    })

    // // 監(jiān)聽連接關(guān)閉 -
    socketTask.onClose((e) => {
        console.log('WebSocket連接關(guān)閉长踊!');
        clearInterval(heartbeatInterval)
        if (!isSocketClose) {
            reconnect(url, onErrorEvent)
        }
    })

    // 監(jiān)聽收到信息
    socketTask.onMessage((res) => {
        uni.hideLoading()
        console.log(res, 'res監(jiān)聽收到信息')
        let serverData = res.data
        //與后端規(guī)定好返回值分別代表什么棚潦,寫業(yè)務(wù)邏輯
        serverData && onReceive(serverData);
    });


}

const reconnect = (url, onErrorEvent) => {
    console.log('進(jìn)入斷線重連', isSocketClose);
    clearInterval(againTimer) //斷線重連定時器
    clearInterval(heartbeatInterval);
    socketTask && socketTask.close(); // 確保已經(jīng)關(guān)閉后再重新打開
    socketTask = null;
    onErrorEvent({
        isShow: true,
        messge: '掃描頭服務(wù)正在連接...'
    })
    // 連接  重新調(diào)用創(chuàng)建websocet方法
    againTimer = setInterval(() => {
        sokcet(url, onReFn, onErrFn, onSucFn)
        console.log('在重新連接中...');
    }, 1000 * 5)


}

const sendMsg = (msg) => { //向后端發(fā)送命令
    msg = JSON.stringify(msg)
    try {
        //通過 WebSocket 連接發(fā)送數(shù)據(jù)
        socketTask.send({
            data: msg
        });
    } catch (e) {
        if (isSocketClose) {
            return
        } else {
            reconnect(url, onErrFn)
        }

    }
}
// 關(guān)閉websocket【必須在實例銷毀之前關(guān)閉,否則會是underfined錯誤】beforeDestroy() {websocetObj.stop();}

const stop = () => {
    isSocketClose = true
    clearInterval(heartbeatInterval);
    clearInterval(againTimer) //斷線重連定時器
    socketTask.close(); // 確保已經(jīng)關(guān)閉后再重新打開
    socketTask = null;
}


const $debounce = function(fn, wait) {
    let timer = null;
    return function() {
        if (timer !== null) {
            clearTimeout(timer);
        }
        timer = setTimeout(fn, wait);
    }
}


export const websocetObj = {
    sokcet,
    stop,
    sendMsg
};

2. 在需要引入的頁面中導(dǎo)入websocket.js

<template>
</template>

<script>
    import {websocetObj} from '@/utils/websock.js';
    export default {
        onLoad() {
            websocetObj.sokcet('ws://192.168.xx.xx:xxx/ws?cid=' + this.cid + '&ip=' + this.IP + '&token=' + this.token, this.getWebsocetData, this.getWebsocetError, this.onErrorSucceed)  //請求地址
        },
        methods: {
            //websocet函數(shù)回調(diào):返回監(jiān)聽的數(shù)據(jù)
            getWebsocetData(val) {
                console.log(val, '函數(shù)回調(diào)'); // 接收參數(shù)
                this.plotterItem.push(val)

            },
            //websocet函數(shù)拋錯: 返回錯誤信息 用于用戶提示
            getWebsocetError(err) {
                this.socketShow = err.isShow;
                this.webtext = err.messge;
                console.log('websocet函數(shù)拋錯', this.socketShow);
            },
            //websocet函數(shù)成功進(jìn)入: 監(jiān)聽連接狀態(tài)儡率,在失敗的時候彈窗提示侯繁,具體需求看自身情況
            onErrorSucceed(val) {
                this.socketShow = val.isShow;
                console.log(val);
                console.log('websocet函數(shù)成功進(jìn)入', this.socketShow);
            },
        }
    }
</script>

<style>
</style>

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末胖喳,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子贮竟,更是在濱河造成了極大的恐慌丽焊,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,744評論 6 502
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件咕别,死亡現(xiàn)場離奇詭異技健,居然都是意外死亡,警方通過查閱死者的電腦和手機惰拱,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,505評論 3 392
  • 文/潘曉璐 我一進(jìn)店門雌贱,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事欣孤〔雒唬” “怎么了?”我有些...
    開封第一講書人閱讀 163,105評論 0 353
  • 文/不壞的土叔 我叫張陵降传,是天一觀的道長篷朵。 經(jīng)常有香客問我,道長婆排,這世上最難降的妖魔是什么声旺? 我笑而不...
    開封第一講書人閱讀 58,242評論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮泽论,結(jié)果婚禮上艾少,老公的妹妹穿的比我還像新娘。我一直安慰自己翼悴,他們只是感情好缚够,可當(dāng)我...
    茶點故事閱讀 67,269評論 6 389
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著鹦赎,像睡著了一般谍椅。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上古话,一...
    開封第一講書人閱讀 51,215評論 1 299
  • 那天雏吭,我揣著相機與錄音,去河邊找鬼陪踩。 笑死杖们,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的肩狂。 我是一名探鬼主播摘完,決...
    沈念sama閱讀 40,096評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼傻谁!你這毒婦竟也來了孝治?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 38,939評論 0 274
  • 序言:老撾萬榮一對情侶失蹤审磁,失蹤者是張志新(化名)和其女友劉穎谈飒,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體态蒂,經(jīng)...
    沈念sama閱讀 45,354評論 1 311
  • 正文 獨居荒郊野嶺守林人離奇死亡杭措,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,573評論 2 333
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了钾恢。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片瓤介。...
    茶點故事閱讀 39,745評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡吕喘,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出刑桑,到底是詐尸還是另有隱情氯质,我是刑警寧澤,帶...
    沈念sama閱讀 35,448評論 5 344
  • 正文 年R本政府宣布祠斧,位于F島的核電站闻察,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏琢锋。R本人自食惡果不足惜辕漂,卻給世界環(huán)境...
    茶點故事閱讀 41,048評論 3 327
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望吴超。 院中可真熱鬧钉嘹,春花似錦、人聲如沸鲸阻。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,683評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽鸟悴。三九已至陈辱,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間细诸,已是汗流浹背沛贪。 一陣腳步聲響...
    開封第一講書人閱讀 32,838評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留震贵,地道東北人利赋。 一個月前我還...
    沈念sama閱讀 47,776評論 2 369
  • 正文 我出身青樓,卻偏偏與公主長得像猩系,于是被迫代替她去往敵國和親媚送。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,652評論 2 354

推薦閱讀更多精彩內(nèi)容

  • 表情是什么蝙眶,我認(rèn)為表情就是表現(xiàn)出來的情緒。表情可以傳達(dá)很多信息褪那。高興了當(dāng)然就笑了幽纷,難過就哭了。兩者是相互影響密不可...
    Persistenc_6aea閱讀 124,976評論 2 7
  • 16宿命:用概率思維提高你的勝算 以前的我是風(fēng)險厭惡者博敬,不喜歡去冒險友浸,但是人生放棄了冒險,也就放棄了無數(shù)的可能偏窝。 ...
    yichen大刀閱讀 6,046評論 0 4