207 похожих чатов

День добрый. Подскажите как лучше реализовать подключение к сокету в

нуксте? Интересует способ чтоб при подключении еще токен пробрасывать
по типу
```
const socket = io('http://localhost:3333', {
extraHeaders: {
authorization: 'token'
}
});
```

14 ответов

8 просмотров

как смотрите на то чтобы io('wss://your.api.host/wss?token=J.W.T') указывать token в get параметрах, чтобы отсекать подключения на "подлёте" у которых неверная сигнатура токена

Ігор-Бойко Автор вопроса
Сергей Rekryt Крупкин
как смотрите на то чтобы io('wss://your.api.host/w...

У меня больше вопрос где его подключать.

Сергей Rekryt Крупкин
как смотрите на то чтобы io('wss://your.api.host/w...

Это же не отличается от вариант Игоря. @igorbojk а в чём проблема? Твой вариант рабочий. Хочешь проверить авторизацию - сделай мидлвар (в socket.io он есть, нативные не трогал)

Ігор-Бойко Автор вопроса
Evgeniy
Это же не отличается от вариант Игоря. @igorbojk ...

Вопрос в том где создавать подключение. По идее подключение должно происходить только если пользователь залогинен. Пока не понимаю где этот инстанс создавать и хранить

Ігор Бойко
Вопрос в том где создавать подключение. По идее п...

допустим в сторе храним пользователя, есть action для аутенттфикации может в нем, проверить что авторизованы и подключаться

Ігор Бойко
Вопрос в том где создавать подключение. По идее п...

Шаблон/vuex и тригерить по авторизации. Всё равно не вижу проблемы.

Ігор-Бойко Автор вопроса
Сергей Rekryt Крупкин
допустим в сторе храним пользователя, есть action ...

это то да, но если сам инстанс сокетов хранить в сторе то vuex ругается так как мі его мутируем при полинге. А если хранить в шаблоне\лейоуте то он не будет доступен во всем приложении. А если его хранить в компоненте самого чата, то он будет пересоздавать подключение вместе с компонентом, чего не хотелось бы

Ігор-Бойко Автор вопроса
Evgeniy
Шаблон/vuex и тригерить по авторизации. Всё равно ...

vuex ругается на хранение инстанса шаблонов несколько и в одном хранить то доступа в других к нему не будет Или вы о чем-то другом?

Ігор Бойко
vuex ругается на хранение инстанса шаблонов нескол...

Я создавал подключение в шаблоне и по событиям использовал vuex в этом случае. Если работаешь с nuxt-socket-io, то попробуй встроенный туда vuex (я не брал т.к. излишен был) В случае нескольких шаблонов - уже лучше вариант Сергея

Ігор Бойко
это то да, но если сам инстанс сокетов хранить в с...

import helper from './helper.js'; // WebSocket let instance = null; class Socket { constructor() { if (instance) return instance; instance = this; this.host = ''; // адрес вебсокета this.session = ''; // сессия пользовтеля this.token = ''; // токен пользовтеля this.$store = null; // vuex this.task = ''; // имя задачи при отправке this.loading = true; // ожидание данных this.debug = process.env.NODE_ENV !== 'production'; // режим дебага return instance; } // events onclose(event) { // ... } // соединение connect(props) { if (props) { this.host = props.host; this.$store = props.$store; } return new Promise((resolve, reject) => { this.$store.commit('api/setConnected', false); // ... }); } // обработка полученных мутаций и действий process({ mutations, actions }) { // ... } // добавить в очередь отправки данных send(task, data = {}) { // ... return new Promise((resolve, reject) => { // ... } } // авторизация auth() { return this.send('auth'); } } export default new Socket();

Ігор-Бойко Автор вопроса
Evgeniy
Я создавал подключение в шаблоне и по событиям исп...

То есть при каждом переходе на шаблон создавалось подключение к сокетам?

Похожие вопросы

Обсуждают сегодня

А чем вам питонисты не угодили?😂
.
79
Ребят, а за скок можно впарить анон чат с апишкой и веб админкой ?
Eugene Неелов
15
Всем привет, написал код ниже, но он выдает сегфолт, в чем причина? #include <stdio.h> #include <stdlib.h> #include <string.h> struct product { char *name; float price; };...
buzz базз
75
Ещё такой вопрос. Мне необходимо хранить пароль пользователя локально. Для этого планирую использовать ini файл. Это для автозаполнения полей логин и пароль при авторизации. Е...
Евгений
19
Добрый день, подскажите как правильно сделать filter в backend-e. Есть модель (товар) у который связь belongsToMany (компания), компаний > 4k, поэтому выборку типа ->all(); н...
Max Dubovsky
7
Привет, имею проблему с better-sqlite3 модулем. После npm install я делаю ребилд модуля под свою текущую версию ноды с помощью npx electron-rebuild -f -m node_modules/better-s...
Anton Samofal
2
Anyone knows how to build this widget in Flutter? I have all the assets for round stations and the road, but how can I make the my widget animate between these stations? And h...
Mohammad Zamani
8
Ты просто гитлеровскую эстетику плохо понимаешь. Он же всё под Цезаря делал. А это как бы запрещённый приём в политике. Пиджаки они зачем все носят? Чтобы показать что они тип...
Ivan Kropotkin
4
hello everyone can you help me above picture figma that give me and belove picture postman that give me api and is it match these?
Sardorbek
6
а чем лучше всего сделать глобальный лок, если много нодов, до сотни? ну то есть мне надо, чтобы некоторые операции с объектом не происходили одновременно. перемещение между н...
Д. П.
15
Карта сайта