一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術(shù)|正則表達(dá)式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務(wù)器之家 - 編程語言 - ASP.NET教程 - 微信小程序如何使用原生Websocket與Asp.Net Core SignalR 通信

微信小程序如何使用原生Websocket與Asp.Net Core SignalR 通信

2023-06-16 00:05未知服務(wù)器之家 ASP.NET教程

背景 如題,這可能算是.net 做小程序的服務(wù)端時(shí),繞不開的一個(gè)問題,老生常談了。同樣的問題,我記得我2018/19年的一個(gè)項(xiàng)目的解決方案是: 修改官方的SignalR.js的客戶端 :把里面用到瀏覽器的Websocket改成微信小程序的官方api的。

背景

如題,這可能算是.net 做小程序的服務(wù)端時(shí),繞不開的一個(gè)問題,老生常談了。同樣的問題,我記得我2018/19年的一個(gè)項(xiàng)目的解決方案是:

修改官方的SignalR.js的客戶端:把里面用到瀏覽器的Websocket改成微信小程序的官方api的。目前網(wǎng)上也有不少這樣的方案,已經(jīng)改好開源了;這種方案的缺點(diǎn)是可能有一段時(shí)間了,可能跟目前自己的服務(wù)端版本不兼容,跟目前自己微信小程序的運(yùn)行環(huán)境不兼容。或者已經(jīng)有些隱藏bug等等,用上寫好業(yè)務(wù)了再發(fā)現(xiàn)bug頭疼得很。使用起來很沒有安全感;

我現(xiàn)在這里的方案是:

直接使用微信小程序的Websocket的原生api與服務(wù)端通信;

原生api文檔:https://developers.weixin.qq.com/minigame/dev/api/network/websocket/wx.connectSocket.html

服務(wù)端

運(yùn)行環(huán)境:.net core 6 On Linux(k8s)ubuntu 18.04

目前已有一個(gè)SignalR的Hub:SmartCutHub.cs

微信小程序如何使用原生Websocket與Asp.Net Core SignalR 通信

可以看到只有紅圈函數(shù)GenerateVideoScript()接收一個(gè)強(qiáng)類型的參數(shù):GenerateVideoScriptDto

ps:強(qiáng)類型參數(shù)傳參時(shí)跟webapi一樣用json對(duì)象即可;

Program.cs注冊(cè):

app.MapHub<SmartCutHub>("/ws/smartcut");
    
//所以路由是
ws://localhost:5055/ws/smartcut

小程序端

創(chuàng)建連接

這里代碼是用的微信小程序原生api,請(qǐng)參考文檔

var wsUrl = "ws://localhost:5055/ws/smartcut";

//創(chuàng)建連接
var conn= await wx.connectSocket({
    url: wsUrl,
    fail(err)
    {
        console.error(err)
    },
    success()
    {
        console.info(wsUrl+"鏈接成功")
    }
})

//創(chuàng)建連接成功
this.connection=conn;
let that=this;

發(fā)送消息

這里的步驟不能省略

conn.onOpen(function (res)
{
    console.log("SocketOpened");

    //先要確認(rèn)協(xié)議,版本
    that.sendStrMsg("{\"protocol\":\"json\",\"version\":1}");
    //確認(rèn)類型
    that.sendStrMsg("{\"type\":6}");
    
    //再發(fā)送消息內(nèi)容
    that.sendStrMsg("{\"arguments\":[{\"scriptType\":\"口播類\",\"productName\":\"許愿池的王八\",\"productSpecialty\":\"在水里,愛許愿,曬太陽\",\"sceneCount\":5,\"sceneMini\":5,\"sceneMax\":10,\"remark\":\"\",\"language\":\"zh\",\"generateCount\":10}],\"invocationId\":\"0\",\"target\":\"GenerateVideoScript\",\"type\":1}");
})

發(fā)送消息函數(shù)

//這里發(fā)送字符串到服務(wù)端
sendStrMsg(msg)
{
	//連接成功后就示例好了
    if(this.connection)
    {
        console.info("準(zhǔn)備發(fā)送:"+msg);
        this.connection.send({
            data: msg+"", //注意,msg這里后面這個(gè)特殊的字符不能省略
            fail(err)
            {
                console.error(err)
            },
            success(res)
            {
                console.info(res)
            },
            complete(res)
            {
                console.info(res)
            }
        });
    }
    else
    {
        console.error("ws連接不存在");
    }
}

總結(jié)

我其實(shí)這里這種方式是模擬瀏覽器端的Websocket傳輸過程的:

微信小程序如何使用原生Websocket與Asp.Net Core SignalR 通信

注意這里消息體后面一樣有這個(gè)特殊字符的

也不算原創(chuàng)和多有技術(shù)含量,可能大家早就理清楚搞定了。但只有能幫到一位朋友我就開心了。ok,今天就水到這。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 99热精品在线免费观看 | 毛片影院 | 国产精品久久久精品视频 | 手机看片自拍自自拍日韩免费 | 麻豆网页| 91资源站| 国产精品亚洲w码日韩中文 国产精品香蕉在线观看不卡 | 91天堂一区二区 | 欧美 变态 另类 人妖班 | 手机看片福利盒子久久 | 2019国内自拍大神视频 | 色呦呦在线免费观看 | 亚洲成人aa | 青青青在线观看国产精品 | 草久热| 国产综合第一页 | 男人的天堂久久爱 | 特黄特级高清免费视频毛片 | 欧美综合精品一区二区三区 | 99久久精品6在线播放 | 国产馆在线观看免费的 | 日你逼| 免费国产好深啊好涨好硬视频 | 欧美成人tv在线观看免费 | 香蕉成人999视频 | 欧美综合另类 | 色综色天天综合网 | 免费视频亚洲 | 男人看的网址 | 亚偷熟乱区视频在线观看 | 欧美日韩视频在线成人 | 亚洲欧洲淘宝天堂日本 | 波多野结衣伦理在线观看 | 国产日日操 | 99热精品在线播放 | 大杳蕉在线影院在线播放 | 吻戏辣妞范1000免费体验 | 亚洲精品国产成人 | 高跟翘臀老师后进式视频 | 女人和拘做受全过程免费 | 闺蜜调教我做她的脚奴 |