使用Rest API在Javascript中启动存档

时间:2019-02-14 06:49:38

标签: opentok

我正在尝试使用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)

有什么想法吗?

1 个答案:

答案 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会代表您这样做。

资源: