• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

question-closed Złapanie error'a axiosem

VPS Starter Arubacloud
+1 głos
80 wizyt
pytanie zadane 11 lipca 2020 w JavaScript przez Greeenone Pasjonat (16,100 p.)
zamknięte 11 lipca 2020 przez Greeenone

Hej,

Mam pewien problem ze złapanie errora przy zapytaniu. Przed załadowanie każdej strony, jest wysyłany token do serwera. Jeśli ten się zgadza, serwer zwraca OK, 200. Jeśli token wygasł lub nie ma go w bazie, serwer zwraca kod

401

{"message":"Unauthenticated."}

I teraz nie wiem jak to wyłapać i zmusić użytkownika do wylogowania się po stronie frontu

To jest gotowy kod sprawdzający czy token jest poprawny:

  [VERIFY_AUTH](context) {
    if (JwtService.getToken()) {
      ApiService.setHeader();
      ApiService.get("/sanctum/verify")
        .then(({ data }) => {
          context.commit(SET_AUTH, data);
        })
        .catch(({ response }) => {
          console.log('Wyloguj')
        });
    } else {
      context.commit(PURGE_AUTH);
    }
  },

I teraz sprawa wygląda następująco:

response zwraca "undefine"

Przerobiłem kod następująco:

  [VERIFY_AUTH](context) {
    if (JwtService.getToken()) {
      ApiService.setHeader();
      ApiService.get("/sanctum/verify")
        .then(({ data }) => {
          context.commit(SET_AUTH, data);
        })
        .catch(() => {
          alert('Wylogowuje');
          context.commit(PURGE_AUTH);
        });
    } else {
      context.commit(PURGE_AUTH);
    }
  },

Gdy token się nie zgadza, pojawia się alert "Wylogowuje" ale już purge Auth się nie wykonuje. Na dodatek, konsola zwraca następujący error:

Uncaught (in promise) Error: Request failed with status code 401
    createError createError.js:16
    settle settle.js:17
    handleLoad xhr.js:61

A tutaj jeszcze kod Api GET:

  get(resource, slug = "") {
    return Vue.axios.get(`${resource}/${slug}`).catch(error => {
      // console.log(error);
      throw new Error(`[KT] ApiService ${error}`);
    });
  },

Jest to prawdopodobnie jakiś problem w przekazywaniu Error'a

komentarz zamknięcia: Rozwiązane
komentarz 11 lipca 2020 przez ScriptyChris Mędrzec (190,190 p.)

Gdy token się nie zgadza, pojawia się alert "Wylogowuje" ale już purge Auth się nie wykonuje. Na dodatek, konsola zwraca następujący error

 Po czym poznajesz, że purge auth się nie wykonuje? Którego Promisa dotyczy ten error?

W niepoprawnym przekazaniu errora chodzi o tą linijkę, gdzie response jest undefined?

.catch(({ response }) => {

Czy metoda context.commit jest synchroniczna?

komentarz 11 lipca 2020 przez Greeenone Pasjonat (16,100 p.)
Dzięki za odpowiedź. Popełniłem gafę. Użytkownik zostawał wylogowany ale link się nie zmieniał. Error pochodził z innego requesta który nie powinien się wykonać

Podobne pytania

0 głosów
0 odpowiedzi 160 wizyt
0 głosów
1 odpowiedź 334 wizyt
0 głosów
2 odpowiedzi 732 wizyt

92,454 zapytań

141,263 odpowiedzi

319,099 komentarzy

61,854 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj.

Akademia Sekuraka

Akademia Sekuraka 2024 zapewnia dostęp do minimum 15 szkoleń online z bezpieczeństwa IT oraz dostęp także do materiałów z edycji Sekurak Academy z roku 2023!

Przy zakupie możecie skorzystać z kodu: pasja-akademia - użyjcie go w koszyku, a uzyskacie rabat -30% na bilety w wersji "Standard"! Więcej informacji na temat akademii 2024 znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...