浏览器中如何实时通过websocket进行实时语音通话传输?
网友回复
我们以php的swoole搭建一个websocket服务器
<?php
$server = new Swoole\WebSocket\Server("0.0.0.0", 9502, SWOOLE_PROCESS, SWOOLE_SOCK_TCP | SWOOLE_SSL);
$server->set([
'daemonize' => false,
'ssl_cert_file' => "/data/cert/6284283_web.debug.only.bfw.wiki.pem",
'ssl_key_file' => "/data/cert/6284283_web.debug.only.bfw.wiki.key",
]);
$server->on('open', function($server, $req) {
echo "connection open: {$req->fd}\n";
});
$server->on('message', function($server, $frame) {
//echo "received message: {$frame->data}\n";
// 确保我们处理的是二进制数据
//if ($frame->opcode == WEBSOCKET_OPCODE_BINARY) {
// 广播音频数据到所有其他连接的客户端
// foreach($server->connections as $fd) {
// if($fd != $frame->fd) {
// $server->push($fd, $frame->data, WEBSOCKET_OPCODE_BINARY);
// }
// }
// }
$server->push($frame->fd, $frame->data,WEBSOCKET_OPCODE_BINARY);
});
$server->on('close', function($server, $fd) {
echo "connection close: {$fd}\n";
});
$server->start();
html代码如下:
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>实时语音通话</title>
</head>
<body>
<button id="startBtn">开始通话</button>
<button id="stopBtn">结束通话</button>
<script>
let ws;
let mediaStream;
let audioContext;
let mediaStreamSource;
let processor;
document.getElementById('startBtn').onclick = s...点击查看剩余70%


