我正在尝试使用javascript进行opentok REST API调用,在网页中嵌入的会话中启动存档。我的JS看起来像这样:
var json_web_token = {
"iss": apiKey,
"ist": "project",
"iat": Date.now(),
"exp": Date.now()+180, // 3 minute expiry, max is 5...
"jti": token
}
//JSON.parse()
var archivedata = {
"sessionId" : sessionId,
"name" : archiveName,
"resolution" : "1280x720",
"layout": "pip"
}
fetch('https://api.opentok.com/v2/project/' + apiKey + '/archive', {
method: 'POST',
mode: 'no-cors',
body: JSON.stringify(archivedata),
headers: new Headers({
'Content-Type': 'application/json',
'X-OPENTOK-AUTH': JSON.stringify(json_web_token),
})
})
.then(response => response.json())
.then(data => {
console.log(data) // Prints result from `response.json()`
})
.catch(error => console.error(error));
但是,我收到以下控制台错误:POST https://api.opentok.com/v2/project/XXXXXXXX/archive 415 (Unsupported Media Type)
有什么想法吗?
答案 0 :(得分:0)
此处是TokBox开发人员的传播者。
生成JWT令牌时,您需要使用JWT库并使用TokBox API Secret对令牌进行签名。由于您使用的是JavaScript,因此可以使用jsonwebtoken包。您用于签名的代码将如下所示:
const jwt = require('jsonwebtoken'); // importing the library
const apiKey = '';
const apiSecret = '';
const currentTime = Math.floor(new Date()/1000);
const token = jwt.sign({
"iss": apiKey,
"ist": "project",
"iat": currentTime,
"exp": currentTime + 180, // maximum is 300
"jti": "jwt_nonce",
}, apiSecret);
请注意,您不应在客户端上生成JWT令牌,因为您随后将暴露API机密。具有API密钥和密钥的任何人都可以像您一样使用OpenTok API。
或者,您可以使用OpenTok Server SDKs来创建OpenTok会话,生成令牌,使用OpenTok存档,广播,SIP等。您不必担心生成JWT令牌,因为服务器SDK会代表您这样做。
资源: