Coder Social home page Coder Social logo

Logout failed about gin-jwt HOT 3 CLOSED

lkgGitHub avatar lkgGitHub commented on June 14, 2024
Logout failed

from gin-jwt.

Comments (3)

rohfle avatar rohfle commented on June 14, 2024 2

There are a couple of limitations that I can see with JWTs by default

  • Tokens will continue to work until they timeout even after logout
  • You can use a token that has been "logged out" to refresh indefinitely
  • There is no way to tell how many sessions you have active

You would need some sort of storage (redis, database, memory) to track sessions and revoked / logged out tokens until they timeout

I think the way to get instant logout with the example is by storing the JWT in a cookie. But the token will still be valid if used in another way (header, query, or manually set cookie) until it times out

From docs:

PROVIDED: LogoutHandler

This is a provided function to be called on any logout endpoint, which will clear any cookies if SendCookie is set, and then call LogoutResponse.

The handler itself

func (mw *GinJWTMiddleware) LogoutHandler(c *gin.Context) {
	// delete auth cookie
	if mw.SendCookie {
		// ... Set cookie
	}

	mw.LogoutResponse(c, http.StatusOK)
}

Docs for setting the JWT in a cookie.
https://github.com/appleboy/gin-jwt#cookie-token

If SendCookie is not true then the JWT cookie will not be set.

from gin-jwt.

samsulbahari avatar samsulbahari commented on June 14, 2024

Have you found a solution?

from gin-jwt.

thangld322 avatar thangld322 commented on June 14, 2024

Can anyone answer please?

from gin-jwt.

Related Issues (20)

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.