Maison >interface Web >js tutoriel >Votre session a expiré !!
Eh bien, aujourd'hui, nous parlons du concept « d'expiration de session », surtout lorsque vous utilisez NextAuth.js dans votre projet. Comprenez dans un langage simple et convivial, pour qu’il n’y ait pas de confusion.
Alors, tout d'abord, comprenons la signification de l'erreur « Votre session a expiré ». Il s'agit d'une erreur liée à l'authentification, qui apparaît lorsque la session de connexion de l'utilisateur est terminée. Par exemple, vous vous êtes connecté à un site Web ou à une application, vous l'avez utilisé pendant un certain temps, puis vous l'avez quitté pendant un certain temps. À mon retour, le message est apparu à l'écran "Session expirée, veuillez vous reconnecter". Cela signifie que l'autorisation qui vous accordait précédemment l'accès à l'application a expiré et vous devrez vous vous reconnecter pour vous authentifier à nouveau. Un exemple pour comprendre : Imaginez, vous êtes dans un centre commercial et l'agent de sécurité vous a donné une
carte de visiteurComment fonctionne NextAuth ma session ? Maintenant, si nous implémentons NextAuth.js, il y a également quelques règles. Lorsqu'un utilisateur se connecte, NextAuth suit son identité à l'aide de JWT (JSON Web Tokens)
ou deest un jeton envoyé après avoir codé les informations d'identification de l'utilisateur, et est envoyé à chaque demande pour vérifier si l'utilisateur est valide ou non. Les Cookies de session sont stockés dans le navigateur, grâce auxquels le backend sait quel utilisateur est actuellement connecté. Mais, ils ont un délai d'expiration
, que vous pouvez définir via laRester connecté : Certaines applications offrent à l'utilisateur la possibilité de "Rester connecté", ce qui prolonge le délai d'expiration de la session. Cela peut être fait en utilisant la rotation des jetons
, où un nouveau jeton est obtenu à chaque demande.
export const authOptions = { session: { strategy: "jwt", // JWT ya session-based approach maxAge: 30 * 60, // 30 minutes ka session timeout }, // baaki authentication providers yahan mention karte hain }
Mécanisme de déconnexion automatique : Dans certains cas, pour des raisons de sécurité, les applications laissent intentionnellement la session expirer plus tôt. Comme dans les applications bancaires, vous remarquerez que si vous êtes inactif pendant un certain temps, la session est déconnectée. Vous pouvez également l'ajouter à votre configuration NextAuth si vous souhaitez maintenir une sécurité élevée.
Scénario réel dans les applications :et avez ajouté quelques articles à votre panier. Si la session expire, vous vous reconnecterez, mais les articles du panier resteront tels quels. Cela est possible car les données du panier peuvent avoir été enregistrées dans le stockage local. Mais dans certaines applications sensibles comme les applications de messagerie ou bancaires, l'utilisateur doit forcer la déconnexion à l'expiration de la session.
Alors mes amis, c'est la base complète de l'expiration de la session et comment NextAuth.js la gère dans votre projet. Ce concept peut paraître déroutant au début, mais lorsque vous le mettez en œuvre dans le monde réel, tout devient progressivement clair. Si vous avez des doutes ou souhaitez en savoir plus sur une pièce spécifique, n'hésitez pas à demander ! ?Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!