我开始使用 WebRTC 进行开发,但那东西从来没有给我提供 ICE 候选人。我设置了一切,我正在交换描述和东西,我还在那里缩小了一个超级丑陋的功能,以确保一切都正确运行,一个接一个。两者的信令状态都是稳定的,onError从未被触发(如预期),但 onIceCandidate 也被触发(不按预期),并且当我想发送随机的空 MediaStream 对象时pc1.addStream(new webkitMediaStream());
,它总是会触发需要谈判.
有谁知道我的代码到底有什么问题吗?我花了几个小时浏览 Stack Overflow、HTML5 Rocks 和 W3C 文档,但我不明白。这是我的整个代码:
var config={
'iceServers':[{
'url':'stun:stun.l.google.com:19302'
},{
'url':'stun:stun1.l.google.com:19302'
},{
'url':'stun:stun2.l.google.com:19302'
},{
'url':'stun:stun3.l.google.com:19302'
},{
'url':'stun:stun4.l.google.com:19302'
}]
};
var pc1=new webkitRTCPeerConnection(config);
var pc2=new webkitRTCPeerConnection(config);
var onError=function(error)
{
console.error(error);
}
pc1.onicecandidate=function()
{
console.log('PC1 onIceCandidate (finally) fired!');
}
pc2.onicecandidate=function()
{
console.log('PC2 onIceCandidate (finally) fired!');
}
pc1.oniceconnectionstatechange=function()
{
console.log('PC1 oniceconnectionstatechange fired!');
}
pc2.oniceconnectionstatechange=function()
{
console.log('PC2 oniceconnectionstatechange fired!');
}
pc1.onnegotiationneeded=function()
{
console.log('PC1 onnegotiationneeded fired!');
}
pc2.onnegotiationneeded=function()
{
console.log('PC2 onnegotiationneeded fired!');
}
pc1.createOffer(function(offer){
pc1.setLocalDescription(offer,function(){
pc2.setRemoteDescription(new RTCSessionDescription(offer),function(){
pc2.createAnswer(function(answer){
pc2.setLocalDescription(answer,function(){
pc1.setRemoteDescription(new RTCSessionDescription(answer),new Function()/*I don't need you, bro*/,onError);
},onError);
},onError);
},onError);
},onError);
},onError);
顺便说一句,我正在使用 Google Chrome 进行开发。我会确保它也能在 Firefox 中运行,但现在问题应该是跨浏览器。我想先进入数据通道...(但我并不反对使用 Firefox 或跨浏览器代码的工作解决方案)