JsSIP播放远程音频

时间:2018-03-29 08:01:15

标签: javascript asterisk sip voip jssip

我在项目中使用带有Asterisk的jsSIP。问题是我不知道如何在我的浏览器中播放Asterisk的音频答案。现在我正在尝试这个

myPhone.on('newRTCSession', function(data){
    var session = data.session;
        session.on('peerconnection', function(e){
            remoteAudio.src = window.URL.createObjectURL(e.stream);
            remoteAudio.play();
        });
    });

但是事件没有被解雇,我也尝试了“addstream”事件,但据我所知,它在我当前的JsSIP版本(3.2.4)中删除了

连接到Asterisk很好。我开始通话,接听答案,然后Asterisk必须播放音频文件,并终止通话。它在连接8秒后终止,但音频没有播放。 以下是RTCSession.connection.remoteDescription.sdp

中的答案
v=0
o=- 857805013 857805013 IN IP4 127.0.0.1
s=-
t=0 0
a=msid-semantic: WMS
m=audio 19006 RTP/SAVPF 0 8 126
c=IN IP4 95.47.143.134
a=rtcp:19007 IN IP4 95.47.143.134
a=candidate:Hc0a80068 1 udp 2130706431 192.168.0.104 19006 typ host generation 0
a=candidate:S5f2f8f86 1 udp 1694498815 95.47.143.134 19006 typ srflx raddr 192.168.0.104 rport 19006 generation 0
a=candidate:Hc0a80068 2 udp 2130706430 192.168.0.104 19007 typ host generation 0
a=candidate:S5f2f8f86 2 udp 1694498814 95.47.143.134 19007 typ srflx raddr 192.168.0.104 rport 19007 generation 0
a=ice-ufrag:218863545319313f5ed15c9b0503a7f1
a=ice-pwd:5e1dc0457efadffe13b44666585eecb9
a=fingerprint:sha-256 56:EE:4C:B8:78:88:AB:A4:C2:72:84:94:15:BE:7C:6E:D4:BD:2F:21:F1:F6:6D:68:E8:91:14:DC:94:72:75:0C
a=setup:active
a=mid:audio
a=sendrecv
a=rtcp-mux
a=rtpmap:0 PCMU/8000
a=rtpmap:8 PCMA/8000
a=rtpmap:126 telephone-event/8000
a=maxptime:150
a=ptime:20

1 个答案:

答案 0 :(得分:1)

有一个名为connection的属性,其中包含RTCPeerConnection个实例中的RTCSession个实例。据我了解,它代表遥控器/其他部分。

因此,这是一个代码示例,显示了如何添加事件侦听器以捕获并使用远程部分的媒体流。

session.connection.addEventListener('addstream', function (e) {
  // set remote audio stream
  const remoteAudio = document.createElement('audio');
  remoteAudio.src = window.URL.createObjectURL(e.stream);
  remoteAudio.play();
});

对于来电,session.connection不会立即实例化。因此,您将需要附加另一个事件侦听器peerconnection来捕获问题中提到的内容。包括该部分,它应如下所示;

session.on('peerconnection', function(data) {
  data.peerconnection.addEventListener('addstream', function (e) {
    // set remote audio stream
    const remoteAudio = document.createElement('audio');
    remoteAudio.src = window.URL.createObjectURL(e.stream);
    remoteAudio.play();
  });
});

有些链接可以帮助您更好地理解它;

  1. JsSIP.RTCSession.connection
  2. RTCPeerConnection.onaddstream