【问题标题】:Failed to set remote answer sdp: Failed to push down transport description: Failed to set SSL role for the channel无法设置远程应答 sdp:无法下推传输描述:无法为通道设置 SSL 角色
【发布时间】:2017-12-09 12:02:28
【问题描述】:

我正在使用 webRTC 构建一个支持音频通话的系统。以下是它的工作原理:
- 用户 A createOffer,然后是 setLocalDescriptionoffer
- 用户 B receiveOffer,然后是 setRemoteDescriptionoffer
- 用户 B createAnswer,然后是 setLocalDescriptionanswer
- 用户 A receiveAnswer,然后是 setRemoteDescriptionanswer

问题是,A收到B的回答后,当A做setRemoteDescription(answer)时,出现这个错误:

未捕获(承诺)DOMException:无法设置远程应答 sdp:无法下推传输描述:无法为通道设置 SSL 角色。

我不知道为什么会出现这个错误。我试着用谷歌搜索它,但到目前为止没有运气。任何帮助将不胜感激!

【问题讨论】:

    标签: ssl webrtc sdp


    【解决方案1】:

    我在重新谈判时遇到了这个问题。我通过确保服务器将 sdp 设置回答为 passive 解决了这个问题。通常这个错误在 chrome firefox 上。

    您也可以在这里查看:https://bugs.chromium.org/p/webrtc/issues/detail?id=2782

    【讨论】:

      【解决方案2】:

      好像是a Firefox bug
      总之,正在发生的事情是:
      - Firefox 提供actpass
      - Chrome 回答 active。这会将 Chrome 设置为 DTLS 客户端,将 Firefox 设置为 DTLS 服务器。
      - Chrome 重新提供,active(因为这是规范所说的,或者至少是我们长期以来对它的解释)
      - Firefox 提供active,但具有相同的 DTLS 指纹。 Chrome 不喜欢这样;它被解释为尝试将 DTLS 角色从 server 更改为 client 而无需创建新关联。
      要解决此问题,我所做的是:确保提供/回答方向保持一致。这意味着,如果 Firefox 生成初始报价,它也会生成所有后续报价。我不确定这种做法有多普遍,但它可能会避免很多互操作错误。
      更详细的讨论:https://groups.google.com/forum/#!topic/discuss-webrtc/gsw3OEAwNKo

      【讨论】:

        猜你喜欢
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 2019-08-18
        • 2020-05-19
        • 1970-01-01
        • 2021-05-09
        • 1970-01-01
        相关资源
        最近更新 更多