javascript - 如何在 JsSIP 中处理音频流?

标签 javascript reactjs typescript sip jssip

我正在创建 React 应用程序,它使用 JsSIP 库来接听通过 VoIP SIP 提供商发出的调用。

我已经创建了一个包含两个按钮(接受和拒绝)的页面。它成功地在 SIP 服务器上注册了 SIP 客户端。它也成功接听电话,我可以接听。但是我在接听电话时听不到任何声音。

注册 JsSIP 客户端(在 willReceiveProps 中,因为我有 props 更改后的连接信息):

const socketHost = 'wss://' + contactCenter.host + ':' + contactCenter.port
const socket = new JsSIP.WebSocketInterface(socketHost)
const configuration = {
    sockets: [socket],
    uri: 'sip:' + contactCenter.login + '@' + contactCenter.host,
    password: contactCenter.password,
    socketHost: socketHost,
}

const coolPhone = new JsSIP.UA(configuration)

coolPhone.on('connected', (e: any) => {
    const messages = ServiceContainer.get<MessageManagerInterface>(ServiceTypes.Messages)
    messages.addSuccess('SIP connected')
})

coolPhone.on('newRTCSession', (e: any) => {
    const messages = ServiceContainer.get<MessageManagerInterface>(ServiceTypes.Messages)
    messages.addAlert('New call')

    const session = e.session

    session.on('failed', this.resetLocalState)
    session.on('ended', this.resetLocalState)

    const numberRegexp = /\"(\d+)\"/
    const fromNumber = (numberRegexp.exec(e.request.headers.From[0].raw))[1]
    const toNumber = (numberRegexp.exec(e.request.headers.Contact[0].raw))[1].slice(1)

    this.setState({
        callReceived: true,
        callSession: session,
        fromNumber: fromNumber,
        toNumber: toNumber,
    })
})

coolPhone.start()

处理回答按钮点击的方法:

private answerCall = () => {
    const messages = ServiceContainer.get<MessageManagerInterface>(ServiceTypes.Messages)
    messages.addSuccess('Call answered')

    const callOptions = {
        mediaConstraints: {
            audio: true, // only audio calls
            video: false
        },
        pcConfig: {
            iceServers: [
                { urls: ["stun:stun.l.google.com:19302"] }
            ],
            iceTransportPolicy: "all",
            rtcpMuxPolicy: "negotiate"
        }
    }

    this.state.callSession.answer(callOptions)

    this.state.callSession.connection.addEventListener('addstream', (event: any) => {
        console.log(event)
        this.audioElement.srcObject = event.stream
    })

    this.audioElement.play()

    this.setState({
        callAnswered: true,
        callReceived: false,
    })
}

我做错了什么?

最佳答案

我解决了这个问题。

问题出在 this.audioElement.play() 行的位置。

我将其移至 addstream 事件的回调中:

this.state.callSession.connection.addEventListener('addstream', (event: any) => {
    console.log(event)
    this.audioElement.srcObject = event.stream
    this.audioElement.play()
})

现在一切正常。希望您也觉得它有用。

关于javascript - 如何在 JsSIP 中处理音频流?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44183387/

相关文章:

javascript - JavaScript 中像 `apples: 5` 这样的行有什么作用?

javascript - 直接原生 JavaScript 或 jQuery 方法获取元素的包含 block

javascript - 切换具有相似 ID 的子元素的父 DIV 以计算其价格

javascript - 如何在 Angular 运行时设置deployUrl

node.js - Angular:ngModel 插值在输入文本框中返回 NaN。如何显示号码

typescript 仅从重载中选择特定方法(要传递给 Parameters<T>)

javascript - 如何访问 Handlebars 中的 URL 参数?

javascript - 如何在 data-grid 组件 column 组件中添加 Edit material-ui 图标

javascript - JS 单元测试使用不同参数运行多次

node.js - 无法在Azure应用程序服务上部署React JS应用程序