gpt4 book ai didi

botframework - 过期后刷新 Directline token

转载 作者:行者123 更新时间:2023-12-04 08:35:49 25 4
gpt4 key购买 nike

我正在将基于 token 的身份验证应用于机器人网络聊天,同时聊天被保留,但在 token 过期后面临问题。无法连接到机器人。
起初,我生成一个 token 并刷新 15 分钟,直到那时一切正常。但是,当用户在没有互联网连接的情况下离线时,假设大约 6-7 小时,由于离线,刷新 token 发布调用不会发生, session 存储中将有一个过期的 token 。晚了他想和他之前做的同样的对话聊天。但是会出现 FailedToConnect 或 ExpiredToken 问题。由于 token 因不事件而过期,无法再次连接到机器人。
我的主要目的是如何将用户与之前的转换联系起来。
提前致谢。

 (async function() {
'use strict';
const {
hooks: { usePostActivity },
hooks: { useDirection },
ReactWebChat
} = window.WebChat;

let { token, conversation_Id } = sessionStorage;
if ( !token ) {
const res = await fetch( 'https:/localhost/api/generateToken', { method: 'POST' } );
const { token: directLineToken, conversationId: conversationId } = await res.json();
sessionStorage[ 'token' ] = directLineToken;
sessionStorage[ 'conversation_Id' ] = conversationId;
token = directLineToken;
conversation_Id = conversationId;
}

if (token) {
await setInterval(async () => {
var myHeaders = new Headers();
myHeaders.append("Authorization","Bearer "+ sessionStorage[ 'token' ]);
let res = await fetch( 'https://directline.botframework.com/v3/directline/tokens/refresh', {
method: 'POST',
headers: myHeaders,
});
const { token: directLineToken, conversationId } = await res.json();
sessionStorage[ 'token' ] = directLineToken;
sessionStorage[ 'conversation_Id' ] = conversationId;
token = directLineToken;
conversation_Id = conversationId;
}, 1000*60*15)}




const store = window.WebChat.createStore({}, ({ dispatch }) => next => action => {
if(action.payload && action.payload.directLine) {
const subscription = action.payload.directLine.connectionStatus$.subscribe({
error: error => console.log( error ),
next: value => {
if ( value === 0 ) {console.log('Uninitialized')}
else if ( value === 1 ) {console.log('Connecting')}
else if ( value === 2 ) {console.log('Online')}
else if ( value === 3 ) {console.log('Expire Token')}
else if ( value === 4 ) {console.log('FailedToConnect')}
else if ( value === 5 ) {console.log('Ended')}
}
});
}
if (action.type === 'DIRECT_LINE/CONNECT_FULFILLED') {
dispatch({
type: 'WEB_CHAT/SEND_EVENT',
payload: {
name: 'Welcome',
value: { language: window.navigator.language }
}
});
}


if (action.type === 'DIRECT_LINE/POST_ACTIVITY') {
action = window.simpleUpdateIn(action, ['payload', 'activity', 'channelData', 'CustomChannel'], () =>"webchat");
}

return next(action);
});


const botconnection = createDirectLine( {token,webSockets: true,watermark: "0" });

window.ReactDOM.render(
<ReactWebChat directLine={botconnection}
store={store}
/>,
document.getElementById('webchat'));
document.querySelector('#webchat > *').focus();
})().catch(err => console.error(err));

最佳答案

不幸的是,一旦 token 过期,就无法获得刷新的 token 以继续对话。请求刷新 token 时,原始 token 必须仍然有效。

关于保持连接,没有很好的选择,但这里有一个可能值得尝试的想法:

  • 创建一个服务,当生成 token 时,它会与用户的在线状态一起发送到此服务。
  • 该服务将管理 token 刷新并将刷新的 token 返回给要使用的原始客户端。
  • 如果用户离线,返回刷新 token 的调用将失败,服务会更新用户的在线状态,并遵循某些条件来停止刷新(例如 4 小时后)。
  • 如果用户重新上线,状态再次更新,刷新的 token 被消耗,对话继续。

  • 希望得到帮助!

    关于botframework - 过期后刷新 Directline token ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/64806603/

    25 4 0
    Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
    广告合作:1813099741@qq.com 6ren.com