首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >FeathersJS套接字jwt认证

FeathersJS套接字jwt认证
EN

Stack Overflow用户
提问于 2018-11-15 18:35:00
回答 1查看 343关注 0票数 0

我正在尝试使用feathersjs向我的应用程序添加身份验证。我很难理解为什么我的jwt令牌没有被发送,即使我从服务器接收到了jwt

以下是我的angular代码:

代码语言:javascript
复制
import {CookieStorage} from 'cookie-storage';
import {JwtHelperService} from '@auth0/angular-jwt';
import feathers from '@feathersjs/feathers';
import socketio from '@feathersjs/socketio-client';
import auth from '@feathersjs/authentication-client';
import {tap} from 'rxjs/operators';
import * as io from 'socket.io-client';

const socket = io('http://localhost:3030');
const cookieStorage = new CookieStorage();
const client = feathers();

client.configure(socketio(socket));
client.configure(auth({ storage: cookieStorage }));

socket.emit('authenticate', userData, function(message, data) {
  console.log(message); // message will be null
  console.log(data); // data will be {"accessToken": "your token"}

  // You can now send authenticated messages to the server
});

这段代码可以工作,我可以将一个jwt accessToken返回到浏览器,但是cookieStorage部分并没有保存cookie。如果我用以下代码切换socket.emit('authenticate')部件,它可以工作:

代码语言:javascript
复制
client.authenticate(userData)

但是,我希望使用socketio进行身份验证,并将jwt保存在cookie中,而不是使用以下方法:

如何使socketio身份验证事件在cookie中设置jwt

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-11-15 21:08:04

client.authenticate(userData)将使用SocketIO进行身份验证(因为您已经在使用client.configure(socketio(socket));),并将其存储在您传递的存储中(在您的示例中是cookieStorage )。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/53325890

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档