Webrtc 信令服务器实现

webrtc建联流程图

由上图可知,所谓的信令服务器其实就是将peer的offer/candidate/answer传给对端而已。这样的话实现方式就有很多种了,目前普遍的方式HTTP/HTTPS,WS/WSS。像webrtc-demo-peerconnection就是实现HTTP这种方式。本文使用WS(websocket)来实现。

简单的协议

peer签到

发送

|-----------|--------|
| src | type |
| 就是peer的名称 | signin |

返回

|------------|------|-----|
| type | code | msg |
| signin_ack | 返回码 | 消息 |

peer数据传输

发送

|-------|-------|-------|------|
| src | dst | type | 其他内容 |
| 发送端名称 | 接收端名称 | trans | ... |

返回

|-----------|------|-----|
| type | code | msg |
| trans_ack | 返回码 | 消息 |

实现代码

1、下载websocketpp/jsoncpp代码:github上找

2、下载boost库

3、先使用cmake生成VS工程,然后编译jsoncpp

4、创建工程SignalServer

主代码如下:

#include "pch.h"

#include <iostream>

#include <websocketpp/config/asio_no_tls.hpp>

#include <websocketpp/server.hpp>

#include <json/json.h>

typedef websocketpp::server<websocketpp::config::asio> server;

server signalserver;

std::mutex g_wcmutex;

std::map<std::string, websocketpp::connection_hdl> g_mapWcInfo;

void on_message(websocketpp::connection_hdl hdl, server::message_ptr msg)

{

std::string strMsg = msg->get_payload();

//解析json

Json::Reader reader;

Json::Value jMsg;

if (!reader.parse(strMsg, jMsg))

{

return;

}

//获取当前的用户名称

std::string strSrcName;

Json::Value jName;

if (!jMsg.isMember("src"))

{

return;

}

jName = jMsg["src"];

strSrcName = jName.asString();

//获取当前的操作

std::string strOptType;

Json::Value jOptType;

if (!jMsg.isMember("type"))

{

return;

}

jOptType = jMsg["type"];

strOptType = jOptType.asString();

//数据转发

if (strOptType.compare("signin") == 0)//peer签到

{

try {

g_wcmutex.lock();

g_mapWcInfo[strSrcName] = hdl;

g_wcmutex.unlock();

signalserver.send(hdl, "{\"type_ack\":\"signin\",\"code\":200,\"msg\":\"success\"}", websocketpp::frame::opcode::text);

}

catch (websocketpp::exception const & e) {

std::cout << "Echo failed because: "

<< "(" << e.what() << ")" << std::endl;

}

}

else if (strOptType.compare("trans") == 0)//数据转发

{

std::string strDstName;

Json::Value jDstName;

if (!jMsg.isMember("dst"))

{

return;

}

jDstName = jMsg["dst"];

strDstName = jDstName.asString();

g_wcmutex.lock();

if (g_mapWcInfo.find(strDstName) == g_mapWcInfo.end())

{

g_wcmutex.unlock();

signalserver.send(hdl, "{\"trans_ack\":\"trans\",\"code\":201,\"msg\":\"failed\"}", websocketpp::frame::opcode::text);

return;

}

else

{

signalserver.send(g_mapWcInfo[strDstName], strMsg, websocketpp::frame::opcode::text);

signalserver.send(hdl, "{\"trans_ack\":\"trans\",\"code\":200,\"msg\":\"success\"}", websocketpp::frame::opcode::text);

}

g_wcmutex.unlock();

}

}

void on_close(websocketpp::connection_hdl hdl)

{

server::connection_ptr ptr = signalserver.get_con_from_hdl(hdl);

g_wcmutex.lock();

std::map<std::string, websocketpp::connection_hdl>::iterator it = g_mapWcInfo.begin();

while (it != g_mapWcInfo.end())

{

server::connection_ptr ptr1 = signalserver.get_con_from_hdl(it->second);

if (ptr1 == ptr)

{

g_mapWcInfo.erase(it);

break;

}

}

g_wcmutex.unlock();

}

int main()

{

signalserver.set_close_handler(&on_close);

signalserver.set_message_handler(&on_message);

signalserver.set_access_channels(websocketpp::log::alevel::all);

signalserver.set_error_channels(websocketpp::log::elevel::all);

signalserver.init_asio();

signalserver.listen(9002);

signalserver.start_accept();

signalserver.run();

}

使用网页在线websocket测试:websocket在线测试

上面是一个最简的信令服务器。

相关推荐
Black蜡笔小新1 小时前
WebRTC嵌入式视频通话SDK:EasyRTC从免插件到轻量级带来的音视频通话技术
音视频·webrtc·sdk·rtc·webp2p
EasyNVR1 小时前
EasyRTC:开启智能硬件与全平台互动新时代
网络·音视频·webrtc·p2p·智能硬件·视频监控
EasyGBS1 小时前
从开发到部署:EasyRTC嵌入式视频通话SDK如何简化实时音视频通信的集成与应用
音视频·webrtc·实时音视频·视频监控
EasyNVR13 小时前
智能硬件新时代,EasyRTC开启物联音视频新纪元
运维·服务器·音视频·webrtc·p2p·智能硬件·视频监控
科技小E16 小时前
EasyRTC:智能硬件适配,实现多端音视频互动新突破
网络协议·安全·小程序·音视频·webrtc·p2p·视频监控
EasyNVR3 天前
EasyRTC智能硬件:小体积,大能量,开启音视频互动新体验
前端·安全·音视频·webrtc·sdk·p2p·智能硬件
科技小E4 天前
WebRTC与EasyRTC:开启智能硬件音视频通讯的全新旅程
网络·网络协议·音视频·webrtc·p2p·视频监控
cyw89984 天前
vue3读取webrtc-stream 视频流
webrtc
Likeadust5 天前
WebP2P+自研回音消除:视频通话SDK嵌入式EasyRTC构建高交互性音视频应用
音视频·webrtc·p2p·webp2p
EasyGBS6 天前
EasyRTC嵌入式WebRTC视频通话SDK支持Web浏览器、Linux、ARM、Android、iOS
arm开发·音视频·webrtc·webp2p