jwt refresh token 1.0

This commit is contained in:
2025-09-21 17:49:55 +03:00
parent 639bc3c1a9
commit 5ddab94773
8 changed files with 95 additions and 19 deletions

View File

@@ -1,3 +1,6 @@
//Разобраться с хранением и использованием refresh token
//Добавить endpoint logout
const token = localStorage.getItem("token");
if (token) {
window.location.href = "./../main/index.html";
@@ -21,11 +24,16 @@ document.getElementById('loginForm').addEventListener('submit', async function (
});
const data = await response.json(); // читаем только один раз
if (response.ok) {
localStorage.setItem("token", data.access_token); // сохраняем только при успехе
const remember_me = document.getElementById("remember").checked
if (response.ok) { // сохраняем только при успехе
if (remember_me) { // если нажат чекбокс, то сохраняем в localstorage со стандартным временем действия
localStorage.setItem("token", data.access_token);
} else { // если не нажат, то в sessionstorage до перезахода в браузер(?)
sessionStorage.setItem("token", data.access_token);
}
window.location.href = './../main/index.html';
} else {
} else { //парсинг и вывод ошибок, если есть
if (Array.isArray(data.detail)) {
const messages = data.detail.map(e => {
const field = e.loc.filter(locPart => locPart !== 'body').join(' -> ');
@@ -42,7 +50,7 @@ document.getElementById('loginForm').addEventListener('submit', async function (
showError(['Connection error: ' + err.message]);
}
});
function showError(messages){
function showError(messages){ //Добавление их на form со стилями
let errorElem = document.getElementById('formError');
let container = document.getElementById('glass-container');
if (!errorElem){