srs信令java版

简介: srs信令java版

会赚钱的人,即使身无分文,也还有自身这个财产。——亚兰

前两天讲到了 srs实现多人聊天室

但是遇到个问题,官方的信令是go语言版的,于是在gpt协助下翻译成java版了

https://gitee.com/VampireAchao/simple-srs-signaling

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://maven.apache.org/POM/4.0.0"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>3.0.2</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
    <groupId>com.example</groupId>
    <artifactId>simple-srs-signaling</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <name>simple-srs-signaling</name>
    <description>simple-srs-signaling</description>
    <properties>
        <java.version>17</java.version>
    </properties>
    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <!-- Spring Boot Starter WebSocket for WebSocket support -->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-websocket</artifactId>
        </dependency>
        <!-- For STOMP messaging protocol over WebSocket -->
        <dependency>
            <groupId>org.webjars</groupId>
            <artifactId>webjars-locator-core</artifactId>
        </dependency>
        <dependency>
            <groupId>org.webjars</groupId>
            <artifactId>sockjs-client</artifactId>
            <version>1.0.2</version>
        </dependency>
        <dependency>
            <groupId>org.webjars</groupId>
            <artifactId>stomp-websocket</artifactId>
            <version>2.3.3</version>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <version>RELEASE</version>
            <scope>compile</scope>
        </dependency>
    </dependencies>
    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>
</project>

当然,代码一股gpt味😄

package com.example.simplesrssignaling;
import com.fasterxml.jackson.databind.ObjectMapper;
import lombok.SneakyThrows;
import org.springframework.web.socket.CloseStatus;
import org.springframework.web.socket.TextMessage;
import org.springframework.web.socket.WebSocketSession;
import org.springframework.web.socket.handler.TextWebSocketHandler;
import java.util.HashMap;
import java.util.Map;
import java.util.concurrent.ConcurrentHashMap;
public class MyWebSocketHandler extends TextWebSocketHandler {
    private final Map<String, Room> nameRootMap = new ConcurrentHashMap<>();
    private final ObjectMapper objectMapper = new ObjectMapper();
    @Override
    public void handleTextMessage(WebSocketSession session, TextMessage message) throws Exception {
        String payload = message.getPayload();
        ActionMessage actionMessage = objectMapper.readValue(payload, ActionMessage.class);
        String action = actionMessage.getMsg().getAction();
        switch (action) {
            case "join" -> handleJoin(actionMessage, session);
            case "publish" -> handlePublish(actionMessage, session);
            case "control" -> handleControl(actionMessage, session);
            default -> {
                // Log or send an error message for unrecognized actions.
            }
        }
    }
    private void handleJoin(ActionMessage actionMessage, WebSocketSession session) {
        String roomName = actionMessage.getMsg().getRoom();
        Room room = nameRootMap.computeIfAbsent(roomName, Room::new);
        Participant participant = new Participant();
        participant.setDisplay(actionMessage.getMsg().getDisplay());
        participant.setSession(session);
        room.add(participant);
        // Prepare response message
        var res = new HashMap<>();
        res.put("action", "join");
        res.put("room", actionMessage.getMsg().getRoom());
        res.put("self", participant); // Assuming you have a toJson method in Participant
        res.put("participants", room.getParticipants()); // Convert list of participants to JSONArray
        var message = new HashMap<>();
        message.put("msg", res);
        message.put("tid", actionMessage.getTid());
        sendMessage(session, message);
        // Notify other participants
        room.notify(session, participant, "join", actionMessage);
    }
    private void handlePublish(ActionMessage actionMessage, WebSocketSession session) {
        String roomName = actionMessage.getMsg().getRoom();
        Room room = nameRootMap.get(roomName);
        if (room != null) {
            Participant participant = room.get(actionMessage.getMsg().getDisplay());
            if (participant != null) {
                participant.setPublishing(true);
                // Notify other participants
                room.notify(session, participant, "publish", actionMessage);
            }
        }
    }
    private void handleControl(ActionMessage actionMessage, WebSocketSession session) {
        String roomName = actionMessage.getMsg().getRoom();
        Room room = nameRootMap.get(roomName);
        if (room != null) {
            Participant participant = room.get(actionMessage.getMsg().getDisplay());
            if (participant != null) {
                // You might need to handle more about control like starting a call, ending a call, etc.
                // Notify other participants
                room.notify(session, participant, "control", actionMessage);
            }
        }
    }
    @SneakyThrows
    private void sendMessage(WebSocketSession session, Object message) {
        if (!session.isOpen()) {
            return;
        }
        String jsonMessage = objectMapper.writeValueAsString(message);
        session.sendMessage(new TextMessage(jsonMessage));
    }
    // Define classes like ActionMessage, JoinResponse, and possibly more based on your needs.
    // This provided code should serve as a base structure upon which you can further build as per requirements.
    @Override
    public void afterConnectionClosed(WebSocketSession session, CloseStatus status) throws Exception {
        super.afterConnectionClosed(session, status);
        nameRootMap.values().removeIf(room -> {
            var participants = room.getParticipants();
            for (Participant participant : participants) {
                if (session.getId().equals(participant.getSession().getId())) {
                    room.remove(participant);
                    var actionMessage = new ActionMessage();
                    room.notify(session, participant, "leave", actionMessage);
                    break;
                }
            }
            return participants.isEmpty();
        });
    }
}
目录
打赏
0
0
0
0
29
分享
相关文章
在 Java 中使用 WebRTC 传输视频——在 Java 中采集音视频
在前面的文章中,我已经介绍了如何使用 WebRTC 的 Native API,通过它们大家应该已经了解了正常 API 的一些使用方法和套路。从本文开始,我将介绍一下我这边对 Native API 默认实现的覆写过程,本文我们将先来介绍一些如何把 Java 中的音视频传输给 WebRTC Lib。
Java UDP通信详解
UDP(User Datagram Protocol)是一种无连接的网络传输协议,它不像TCP那样需要建立连接和维护状态,因此更加轻量级。UDP适用于那些对数据传输的实时性要求较高,可以容忍一定数据丢失的场景。本文将详细介绍Java中如何使用UDP协议进行网络通信,包括UDP套接字、数据传输、服务器和客户端的创建等。
213 0
java202303java学习笔记第三十九天Udp协议发送数据1
java202303java学习笔记第三十九天Udp协议发送数据1
105 0
java202303java学习笔记第三十九天单播,组播,广播1
java202303java学习笔记第三十九天单播,组播,广播1
94 0
java202303java学习笔记第三十九天Udp协议接收数据
java202303java学习笔记第三十九天Udp协议接收数据
79 0
在 Java 中使用 WebRTC 传输视频——准备工作
最近一段时间的主要工作内容是开发一个远程控制手机的功能,其中音视频传输的部分是采用WebRTC技术来进行的,而我们的手机都是通过与其直接连接的Agent服务器进行管理,Agent服务是Java写的,现在市面上又没有合适的Java版WebRTC库,所以我就基于Google开源代码,写了一个JNI调用WebRTC Native的库。之前的一篇文章,我主要讲了讲我是怎么编译WebRTC的。这篇文章,我就来分享一下我是怎么在Java中使用WebRTC的,以及我根据业务需要对WebRTC的一些改动。
在 Java 中使用 WebRTC 传输视频——端口限制和自定义编解码
在本文中,我们将继续介绍一些对 WebRTC Native Lib 的覆写过程,主要涉及如何限制端口的使用以及如何重写编解码过程。
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等