美文网首页
用swift搭建一个WebRTC的信令服务器

用swift搭建一个WebRTC的信令服务器

作者: coder_xiang | 来源:发表于2020-05-15 16:52 被阅读0次

下载项目到本地, 直接在xcode运行即可, 请查看打印输出的信息. 请配合webrtc的客户端使用.
项目GitHub地址: https://github.com/Xianlau/WebRTC_SignallingServer/tree/master

比较简单, 而且我在代码上已经注释详细, 大家直接看代码就好了, 一共就三个类文件:

image.png
  • main.swfit
import Foundation

let server = try WebSocketServer()
server.start()
RunLoop.main.run()
  • 本机开启的服务器对象
//本机开启的服务器对象

import Foundation
import Network

final class WebSocketServer {
    
    //global线程
    private let queue = DispatchQueue.global()
    //端口
    private let port: NWEndpoint.Port = 8080
    //网络监听者
    private let listener: NWListener
    //用Set来存放连接进来的客户端对象
    private var connectedClients = Set<WebSocketClient>()
    
    // MARK:- 初始化后台服务
    init() throws {
        let parameters = NWParameters.tcp//TCP连接方式
        let webSocketOptions = NWProtocolWebSocket.Options()//连接属性设置
        webSocketOptions.autoReplyPing = true//自动回复ping包
        parameters.defaultProtocolStack.applicationProtocols.append(webSocketOptions)
        self.listener = try NWListener(using: parameters, on: self.port)//设置连接相关的方式和参数
    }
    
    // MARK:- 开启后台服务
    func start() {
        //设置接收到消息的处理方法
        self.listener.newConnectionHandler = self.newConnectionHandler
        //开启后台服务监听
        self.listener.start(queue: queue)
        print("信令服务器开始监听端口 \(self.port)")
    }
    
    // MARK:- 接收到一个新的client的处理方法
    private func newConnectionHandler(_ connection: NWConnection) {
        let client = WebSocketClient(connection: connection)//新建一个客户端对象
        self.connectedClients.insert(client)//往set里面插入一个客户端对象
        client.connection.start(queue: self.queue)//开始连接这个客户端
        //接收到这个客户端的数据
        client.connection.receiveMessage { [weak self] (data, context, isComplete, error) in
            //数据处理
            self?.didReceiveMessage(from: client, data: data, context: context, error: error)
        }
        print("有一个客户端连进来了, 现在连接的客户端总数: \(self.connectedClients.count)")
    }
    // MARK:- 断开一个client
    private func didDisconnect(client: WebSocketClient) {
        self.connectedClients.remove(client)
        print("有一个客户端断开了, 现在连接的客户端总数: \(self.connectedClients.count)")

    }
    
    // MARK:- 收到来自client的信息 处理数据
    private func didReceiveMessage(from client: WebSocketClient,
                                   data: Data?,
                                   context: NWConnection.ContentContext?,
                                   error: NWError?) {
        
        if let context = context, context.isFinal {//如果是收到终止连接的context信息
            client.connection.cancel()//取消连接
            self.didDisconnect(client: client)//断开连接
            return
        }
        //如果收到data数据, 分发给其他client
        if let data = data {
            let otherClients = self.connectedClients.filter { $0 != client }//能用这个语法是因为实现了equal协议
            //把这个客户端发过来的数据转发给其他client
            self.broadcast(data: data, to: otherClients)
            //打印收到的数据
            if let str = String(data: data, encoding: .utf8) {
                print("------------------------------------ 接收到 数据信息 ------------------------------------")
                print(str + "\n")
            }
        }
        //继续接收消息
        client.connection.receiveMessage { [weak self] (data, context, isComplete, error) in
            self?.didReceiveMessage(from: client, data: data, context: context, error: error)
        }
    }
    // MARK:- 发送数据给其他client
    private func broadcast(data: Data, to clients: Set<WebSocketClient>) {
        clients.forEach {
            let metadata = NWProtocolWebSocket.Metadata(opcode: .binary)//元数据
            let context = NWConnection.ContentContext(identifier: "context", metadata: [metadata])
            //发送数据
            $0.connection.send(content: data,
                               contentContext: context,
                               isComplete: true,
                               completion: .contentProcessed({ _ in }))
        }
    }
}

  • 检测到的客户端的对象
//检测到的客户端的对象

import Foundation
import Network

final class WebSocketClient: Hashable, Equatable {//继承哈希协议, 才能放进去set集合
    
    let id: String
    let connection: NWConnection
    
    
    init(connection: NWConnection) {
        self.connection = connection
        //获取随机UUID
        self.id = UUID().uuidString
    }
    
    // MARK:- 判断等价的条件 Equatable协议
    ///Returns a Boolean value indicating whether two values are equal.
    static func == (lhs: WebSocketClient, rhs: WebSocketClient) -> Bool {
        lhs.id == rhs.id
    }
    // MARK:- 提供一个哈希标识
    /// Hashes the essential components of this value by feeding them into the given hasher.
    func hash(into hasher: inout Hasher) {
        hasher.combine(id)
    }
}

相关文章

  • WebRTC 服务器要干些什么

    概述 WebRTC 的服务器大体分为信令服务器和媒体服务器 WebRTC 信令服务器是主要功能是为 WebRTC ...

  • 用swift搭建一个WebRTC的信令服务器

    下载项目到本地, 直接在xcode运行即可, 请查看打印输出的信息. 请配合webrtc的客户端使用.项目GitH...

  • webrtc

    使用WebRTC搭建前端视频聊天室——入门篇使用WebRTC搭建前端视频聊天室——信令篇Android之WebRTC介绍

  • Webrtc服务器搭建

    Webrtc服务器包括:房间服务器(Room Server)、信令服务器(Signaling Server)、防火...

  • WebRTC信令交互流程

    WebRTC信令交互流程: 上述序列中,WebRTC并不提供Stun服务器和Signal服务器,服务器端需要自己实...

  • WebRTC学习(二)

    信令服务器 没有信令服务器,各个WebRTC之间是没办法通信的。传递媒体数据有两个信息,必须经过信令服务器进行交换...

  • iOS基于WebRTC的音视频直播实用Demo(附图)

    本Demo包括了swift搭建的本地信令服务器 先展示demo效果图 demo下载地址:https://githu...

  • 搭建WebRtc服务器

    搭建WebRtc服务器 一、建立webrtc目录(服务器存放位置,发布时使用) 创建webrtc目录 二、安装no...

  • Web网页音视频通话之基于SIPJS

    简述本文是以FreeSwitch作为信令服务器,通过sipjs(基于webRtc) 进行媒体协商,网络协商后,进行...

  • js实现WebRTC点对点视频通话

    先看页面代码,这里使用的webRTC原生的API。目前信令服务器使用的是websocket实现的,后续改成将soc...

网友评论

      本文标题:用swift搭建一个WebRTC的信令服务器

      本文链接:https://www.haomeiwen.com/subject/mezcohtx.html