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

Всем привет. Я ознакомился с теорией jwt, и теперь хочу

удостовериться что я всё правильно понял. Сейчас будет небольшой теоретический вопрос, извиняюсь если он будет слишком глупым)
У нас есть access токен, который обновляется за счёт refresh токена. Когда происходит авторизация пользователя в системе, ему в localstorage передаётся access токен. И каждый раз, когда пользователь обращается к серверу, он отправляет этот access токен, и если он правильный, то сервер делает то что хочет пользователь, и так же возвращает ему уже новый access токен. + access токен обновляется сам, через указанное время с помощью refresh токена (и refresh токен тоже обновляется, но уже не так часто как access).
Вопросы:
1)Всё ли я правильно понял?
2)Теоретически, в такой системе не может быть одновременно авторизированно два пользователя, верно?

10 ответов

7 просмотров
Alex- Автор вопроса

Ну access токен в локал сторедж, а refresh в httpOnly cookie

Alex- Автор вопроса

Ты про access?

Alex
Ты про access?

Нет. Ты можешь создать несколько токенов, для разных подключений. Авторизуешься где-то — выдается новый токен, с которым можно войти, а старый не удаляется, следовательно и сессия по нему живет. Количество общих подключений можно контролировать

Alex- Автор вопроса
✙ Nikita 🇺🇦🇵🇱🇱🇻🇱🇹🇪🇪🇺🇸🇬🇧🇨🇿🇫🇷🇩🇪🇮🇹🇧🇬🇹🇼🇯🇵🇰🇷🇹🇷🇪🇸🇬🇷
сервер не отдает новый токен на каждый запрос

Да, перечитал ещё пару статей, ты прав)) at(access toket);rt(refresh token) Но ещё такой вопрос. Вот я отправляю jwt, и после того как мой at заканчивается, я отправляю rt. И в ответ получаю новый jwt+rt. Но как я пойму что rt уже закончился? То есть я слышал что они долгоживущие. Но как серверу понять что его жизнь закончена?;)

Alex- Автор вопроса
✙ Nikita 🇺🇦🇵🇱🇱🇻🇱🇹🇪🇪🇺🇸🇬🇧🇨🇿🇫🇷🇩🇪🇮🇹🇧🇬🇹🇼🇯🇵🇰🇷🇹🇷🇪🇸🇬🇷
Рефреш сервер хранит у себя

Но он же его тоже обновляет, рефреш то одноразовый. Как он поймёт то что хватит принимать этот refresh?

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

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

Комрады, хотел уточнить. Проперть в OnDestroy юнита-хозяина по-прежнему доступна? И еще уточнение: finalization юнита наступает раньше или позже OnDestroy?
Ed Doc
38
Проблема с Windows scripting control Множество объектов получают iDispatch обертки и отдаются в скрипты. При этом скрипты могут эти обертки держать живыми очень долго, наприм...
Arioch The
16
Я тут пытаюсь переработать архитектуру подсистемы памяти ядра во что-то осмысленное. Есть pmm, который создает набор range’ей(пока что только для ядра, потом для юзерспейса), ...
Evg Resh
9
Скажите, можно ли как-то "переместить" динамический массив из одной переменной в другую? Скажем, переместить из TList<> в TArray<>. Именно переместить, а не скопировать. Если ...
Eugene Krasnikov (ᴊɪɴ x)
37
комрады, че-та лыжы не едут var tmpFont: TFont; begin tmpFont:= TFont.Create; try case rgFontColor.ItemIndex of 0: tmpFont.Color:= clWindowText; 1: tmpFo...
Ed Doc
34
Вот еще криповенькая штука. uMain.pas(517,3) Warning: Case statement does not handle all possible cases И ЧО? 😂
Александр (Rouse_) Багель
20
Интересно, нет ли какого-то способа получить из dll не адрес самой метки, а адрес со смещением?
The Bird of Hermes
54
коллеги, а есть простой способ определить, что программу из под Delphi запускают?
Михаил
10
40 тысяч в час / 3600 = 11,11 в секунду... Вам точно нужна очередь? (я просто не знаю "контекста") Такое количество запросов любое приложение замечательно "прожует" и не попер...
Igor Mitin
5
М-да. Почему бы просто со stringlist не работать?
Michael Longneck
23
Карта сайта