首页 > 解决方案 > botframework 网络聊天令牌发布调用返回 403

问题描述

我正在使用此示例将机器人集成到网络聊天中。

<!DOCTYPE html>
<html lang="en-US">
  <head>
    <title>Web Chat: Send welcome event</title>
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <script crossorigin="anonymous" src="https://cdn.botframework.com/botframework-webchat/latest/webchat.js"></script>
    <style>
      html,
      body {
        height: 100%;
      }

      body {
        margin: 0;
      }

      #webchat {
        height: 100%;
        width: 100%;
      }
    </style>
  </head>
  <body>
    <div id="webchat"></div>
    <script>
      (async function() {
        const res = await fetch('https://directline.botframework.com/v3/directline/tokens/generate', 
        { method: 'POST',
        headers: { Authorization: 'my webchat secret' }
        });
        const { token } = await res.json();
        const store = window.WebChat.createStore({}, ({ dispatch }) => next => action => {
          if (action.type === 'DIRECT_LINE/CONNECT_FULFILLED') {
            dispatch({
              type: 'WEB_CHAT/SEND_EVENT',
              payload: {
                name: 'webchat/join',
                value: { language: window.navigator.language }
              }
            });
          }

          return next(action);
        });

        window.WebChat.renderWebChat(
          {
            directLine: window.WebChat.createDirectLine({ token }),
            store
          },
          document.getElementById('webchat')
        );

        document.querySelector('#webchat > *').focus();
      })().catch(err => console.error(err));
    </script>
  </body>
</html>

请在控制台中找到错误消息

在此处输入图像描述

但是,当我尝试使用与我的机器人密码相同的 api url 作为邮递员中的授权时,我得到 200 OK 响应,其中包含“conversationId”、“token”和“expires_in”值。

我在电话后遗漏了什么?

标签: javascriptbotframework

解决方案


我认为您可能缺少Authorization标头中的Bearer部分。

所以,它应该是这样的:

headers: { Authorization: 'Bearer my webchat secret' }

推荐阅读