2017-05-27 62 views
0

我在尋找錯誤時遇到了麻煩,任何人都可以爲我指出問題,我已經進入了這個2天,但仍然無法弄清楚。在Xirsys中獲取Ice配置時發生錯誤

error log

上面的圖片是從Heroku的錯誤日誌。

這裏是冰配置我server.js

// Load required modules 
var http = require("http");    // http server core module 
var https = require('https'); 
var express = require("express");   // web framework external module 
var serveStatic = require('serve-static'); // serve static files 
var socketIo = require("socket.io");  // web socket external module 
var easyrtc = require('./lib/easyrtc_server');    // EasyRTC external module 

// Set process name 
process.title = "node-easyrtc"; 

//設置和配置快速HTTP服務器。預計稱爲「靜態」的子文件夾將成爲Web根目錄。

var app = express(); 

app.use(serveStatic('public', {'index': ['index.html']})); 

var port = process.env.PORT || 8080; 

//開始快速端口8080

var webServer = http.createServer(app).listen(port); 

//開始Socket.io HTTP服務器,因此它自身附加到Express服務器

var socketServer = socketIo.listen(webServer, {"log level":1}); 




easyrtc.setOption("logLevel", "debug"); 

//覆蓋默認easyrtcAuth監聽器,只有這樣我們可以直接訪問它的回調

easyrtc.events.on("easyrtcAuth", function(socket, easyrtcid, msg, socketCallback, callback) { 
easyrtc.events.defaultListeners.easyrtcAuth(socket, easyrtcid, msg, socketCallback, function(err, connectionObj){ 
    if (err || !msg.msgData || !msg.msgData.credential || !connectionObj)  
{ 
     callback(err, connectionObj); 
     return; 
    } 

    connectionObj.setField("credential", msg.msgData.credential, {"isShared":false}); 

    console.log("["+easyrtcid+"] Credential saved!", connectionObj.getFieldValueSync("credential")); 

    callback(err, connectionObj); 
}); 
}); 

//要測試,讓我們將證書打印到每個房間加入的控制檯!

easyrtc.events.on("roomJoin", function(connectionObj, roomName, roomParameter, callback) { 

console.log("["+connectionObj.getEasyrtcid()+"] Credential retrieved!", connectionObj.getFieldValueSync("credential")); 

easyrtc.events.defaultListeners.roomJoin(connectionObj, roomName, roomParameter, callback); 
}); 

//開始EasyRTC服務器

var rtc = easyrtc.listen(app, socketServer, null, function(err, rtcRef) { 
console.log("Initiated"); 

rtcRef.events.on("roomCreate", function(appObj, creatorConnectionObj, roomName, roomOptions, callback) { 
    console.log("roomCreate fired! Trying to create: " + roomName); 

    appObj.events.defaultListeners.roomCreate(appObj, creatorConnectionObj, roomName, roomOptions, callback); 
}); 
}); 

//冰配置easyrtc

easyrtc.on("getIceConfig", function(connectionObj, callback) { 

// This object will take in an array of XirSys STUN and TURN servers 
var iceConfig = []; 

http.request({ 
    url: 'https://service.xirsys.com/ice', 
    qs: { 
     ident: "***", 
     secret: "****", 
     domain: "***", 
     application: "test-livestream", 
     room: "test-livestream-room", 
     secure: 1 
}, 
function (error, response, body) { 
    if (!error && response.statusCode == 200) { 
     // body.d.iceServers is where the array of ICE servers lives 
     iceConfig = body.d.iceServers; 
     console.log(iceConfig); 
     callback(null, iceConfig); 
    } 
    else 
    { 
     console.log(error); 
    } 
    } 
}); 
}); 

//在8080端口上

webServer.listen(8080, function() { 

console.log('listening on http://localhost:'+port); 
}); 

回答

0

聽通過增加另一個模塊

var request = require("request"); 

和編輯工作我的冰服務器

request.post('https://service.xirsys.com/ice',{ 
    form:{ 
     ident: "****", 
     secret: "****", 
     domain: "****", 
     application: "****", 
     room: "****", 
     secure: 1 
    }, 
    json:true 
}, 

我得讓它工作:)

相關問題