Git Product home page Git Product logo

Comments (4)

ttbarnes avatar ttbarnes commented on July 4, 2024

This seems to have been an issue with an 'old' user I was using. This was specifically for a unit test environment.

After creating a brand new user, everything works as expected. GET requests with the users's JWT in Authorization header work perfectly.

It seems that the previous user being used for authentication, was somehow using an invalid JWT. Maybe related to the way the JWT is created inline with the user schema.

Therefore it makes sense that passport.authenticate('jwt' .... was just not working at all and hence, no requests or responses - because it was an invalid jwt.

Interested to know if there could be another reason, or if I could be wrong :)

from passport-jwt.

mikenicholson avatar mikenicholson commented on July 4, 2024

Is this still an issue? I see that it was closed and reopened.

Without seeing your code or an example program that reproduces the issue there isn't enough information here for me to help you.

There could be a number of reasons why your jwt is not validating. Could it be expired? Jwt's are generally created with an expiration time. If you're creating it and storing it in the DB(you mention creating it with a user schema??) then perhaps it is expiring after some period and that is why it no longer works.

Again, I'm just guessing. There is not nearly enough information here.

from passport-jwt.

ttbarnes avatar ttbarnes commented on July 4, 2024

Thanks @themikenicholson - this is no longer an issue, I reopened just incase someone had some ideas about what could cause this.

We added expiration to the JWT, however In my test environment, the user would have got a fresh JWT created, before other auth-only endpoints would be hit.

There was some missing fields in the user. I guess that somehow between adding new fields to the user schema and adding a JWT expiry, the specific User/JWT in question would not work. Maybe something to do with the encryption side.

If I come across this issue again i'll create an example.

from passport-jwt.

fromage9747 avatar fromage9747 commented on July 4, 2024

@ttbarnes I just encountered this issue with the project I am working on. It was with a user account that I created when I first built the app however the JWT expiry has been the same since the start. Not sure what caused it. I too would be interested in how it happened. Spent two days with troubleshooting ruling out other possibilities. I was able to successfully login with a newer user account.

I can confirm that a new token is created each time I login with the old account:
1st Login
JWT eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.{"online_status":{"is_online":false,"socket_id":"","online_status_string":"offline","last_seen_date":"2019-10-18T07:20:32.355Z"},"timestamps":{"verified_date":"2018-07-29T08:31:51.922Z","modified_date":"2019-10-19T07:34:36.991Z","created_date":"2018-07-29T08:30:40.064Z","last_login_date":"2019-10-19T07:34:36.991Z"},"sidebar_status":true,"roles":[],"isVerified":true,"public_search":false,"payment_instructions":"Congratulations on winning my auction!\n\nPlease make payment via the payment option you selected in my listing.\n\nOnce payment has been made your item will be shipped out using the chosen shipping method.\n\nIf you wish to get in touch with me please navigate to your messages and you will find that my contact regarding this sale has been added as a conversation.\n\nI look forward to receiving payment, completing the sale and making you happy.\n\nMjölnir is the best and safest place to trade online in Russia.","feedback_percent":100,"_id":"5b5d7b306ca7874ee1d064ef","full_name":"Jared Merson","email_address":"jnm9747@gmail.com","username":"fromage9747","password":"$2a$10$IX6TrZLiJ9M2UhgJgREzWOq3D1Ftb7ObRpKmcF0HVWGjIv./dIbJS","terms_and_conditions":true,"activationToken":"fb1e6cdc880bf834c205553d7c5fd8eac6ae356b","__v":0,"profile_picture_main":"84590bb103a1d671b6e131574ebc8a8e.jpg","date_of_birth":"1988-09-01T00:00:00.000Z","description":"Congratulations on winning my auction!\n\nPlease make payment via the payment option you selected in my listing.\n\nOnce payment has been made your item will be shipped out using the chosen shipping method.\n\nIf you wish to get in touch with me please navigate to your messages and you will find that my contact regarding this sales has been added as a conversation.\n\nI look forward to receiving payment, completing the sale and making you happy.\n\nMjölnir is the best and safest place to trade online in Russia.","first_name":"Jared","gender":"male","last_name":"Merson","logged_locations":[{"device_data":{"browser":"chrome","browser_version":"71.0.3578.98","device":"unknown","os":"windows","os_version":"windows-10","userAgent":"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/71.0.3578.98 Safari/537.36"},"location_data":{"business_website":"","city":"Novosibirsk","continent":"Europe","country_code":"RU","internet_provider_name":"l37-192-166-42.novotelecom.ru","internet_provider_type":"Residential","internet_service_provider":"Novotelecom Ltd","latitude":"55.0411","longitude":"82.9344","organization":"Novotelecom Ltd","ip_address":"37.192.166.42","region":"Novosibirsk","status":"success"},"timestamps":{"created_date":"2019-01-25T17:04:11.932Z"},"_id":"5c4b418bf061e30e33bc9df0"},{"device_data":{"browser":"chrome","browser_version":"71.0.3578.99","device":"android","os":"android","os_version":"unknown","userAgent":"Mozilla/5.0 (Linux; Android 8.0.0; SM-N950F) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/71.0.3578.99 Mobile Safari/537.36"},"location_data":{"business_website":"","city":"Novosibirsk","continent":"Europe","country_code":"RU","internet_provider_name":"l37-192-166-42.novotelecom.ru","internet_provider_type":"Residential","internet_service_provider":"Novotelecom Ltd","latitude":"55.0411","longitude":"82.9344","organization":"Novotelecom Ltd","ip_address":"37.192.166.42","region":"Novosibirsk","status":"success"},"timestamps":{"created_date":"2019-01-27T03:33:45.288Z"},"_id":"5c4d2699b7d9df3016c3fcd5"},{"device_data":{"browser":"Chrome","browser_version":"75.0.3770.142","device":"Unknown","os":"Windows","os_version":"windows-10","userAgent":"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/75.0.3770.142 Safari/537.36"},"location_data":{"business_website":"","city":"Iskitim","continent":"Europe","country_code":"RU","internet_provider_name":"l37-192-166-42.novotelecom.ru","internet_provider_type":"Residential","internet_service_provider":"Novotelecom Ltd","latitude":"54.6366","longitude":"83.3045","organization":"Novotelecom Ltd","ip_address":"37.192.166.42","region":"Novosibirsk Oblast","status":"success"},"timestamps":{"created_date":"2019-07-23T06:01:53.242Z"},"_id":"5d36a2d132ce8d044d2ef637"},{"device_data":{"browser":"Chrome","browser_version":"76.0.3809.111","device":"Unknown","os":"Android","os_version":"unknown","userAgent":"Mozilla/5.0 (Linux; Android 9; SM-G950F) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/76.0.3809.111 Mobile Safari/537.36"},"location_data":{"business_website":"","city":"Iskitim","continent":"Europe","country_code":"RU","internet_provider_name":"l37-192-166-42.novotelecom.ru","internet_provider_type":"Residential","internet_service_provider":"Novotelecom Ltd","latitude":"54.6366","longitude":"83.3045","organization":"Novotelecom Ltd","ip_address":"37.192.166.42","region":"Novosibirsk Oblast","status":"success"},"timestamps":{"created_date":"2019-08-26T09:10:51.298Z"},"_id":"5d63a21babee6303bce4c61a"},{"device_data":{"browser":"Chrome","browser_version":"76.0.3809.111","device":"Unknown","os":"Android","os_version":"unknown","userAgent":"Mozilla/5.0 (Linux; Android 9; SM-N950F) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/76.0.3809.111 Mobile Safari/537.36"},"location_data":{"business_website":"","city":"Novosibirsk","continent":"Europe","country_code":"RU","internet_provider_name":"81.mtsnet.ru","internet_provider_type":"Residential","internet_service_provider":"MR Sibir","latitude":"55.0415","longitude":"82.9346","organization":"MR Sibir","ip_address":"213.87.224.81","region":"Novosibirsk Oblast","status":"success"},"timestamps":{"created_date":"2019-10-01T12:11:23.185Z"},"_id":"5d93426be6f8250345823a76"},{"device_data":{"browser":"Firefox","browser_version":"69.0","device":"Unknown","os":"Windows","os_version":"windows-10","userAgent":"Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:69.0) Gecko/20100101 Firefox/69.0"},"location_data":{"business_website":"","city":"Iskitim","continent":"Europe","country_code":"RU","internet_provider_name":"l37-192-166-42.novotelecom.ru","internet_provider_type":"Residential","internet_service_provider":"Novotelecom Ltd","latitude":"54.6366","longitude":"83.3045","organization":"Novotelecom Ltd","ip_address":"37.192.166.42","region":"Novosibirsk Oblast","status":"success"},"timestamps":{"created_date":"2019-10-18T07:15:25.665Z"},"_id":"5da9668df01fc98c8df3edc8"}],"listing_watchlist":[],"iat":1571478540,"exp":1572083340}._q2h_xBslt0tHGVjabOfk2bNWQh0N6ZnDwxp-YYbYrc
2nd login
JWT eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.{"online_status":{"is_online":false,"socket_id":"","online_status_string":"offline","last_seen_date":"2019-10-18T07:20:32.355Z"},"timestamps":{"verified_date":"2018-07-29T08:31:51.922Z","modified_date":"2019-10-19T09:49:00.025Z","created_date":"2018-07-29T08:30:40.064Z","last_login_date":"2019-10-19T09:49:00.025Z"},"sidebar_status":true,"roles":[],"isVerified":true,"public_search":false,"payment_instructions":"Congratulations on winning my auction!\n\nPlease make payment via the payment option you selected in my listing.\n\nOnce payment has been made your item will be shipped out using the chosen shipping method.\n\nIf you wish to get in touch with me please navigate to your messages and you will find that my contact regarding this sale has been added as a conversation.\n\nI look forward to receiving payment, completing the sale and making you happy.\n\nMjölnir is the best and safest place to trade online in Russia.","feedback_percent":100,"_id":"5b5d7b306ca7874ee1d064ef","full_name":"Jared Merson","email_address":"jnm9747@gmail.com","username":"fromage9747","password":"$2a$10$IX6TrZLiJ9M2UhgJgREzWOq3D1Ftb7ObRpKmcF0HVWGjIv./dIbJS","terms_and_conditions":true,"activationToken":"fb1e6cdc880bf834c205553d7c5fd8eac6ae356b","__v":0,"profile_picture_main":"84590bb103a1d671b6e131574ebc8a8e.jpg","date_of_birth":"1988-09-01T00:00:00.000Z","description":"Congratulations on winning my auction!\n\nPlease make payment via the payment option you selected in my listing.\n\nOnce payment has been made your item will be shipped out using the chosen shipping method.\n\nIf you wish to get in touch with me please navigate to your messages and you will find that my contact regarding this sales has been added as a conversation.\n\nI look forward to receiving payment, completing the sale and making you happy.\n\nMjölnir is the best and safest place to trade online in Russia.","first_name":"Jared","gender":"male","last_name":"Merson","logged_locations":[{"device_data":{"browser":"chrome","browser_version":"71.0.3578.98","device":"unknown","os":"windows","os_version":"windows-10","userAgent":"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/71.0.3578.98 Safari/537.36"},"location_data":{"business_website":"","city":"Novosibirsk","continent":"Europe","country_code":"RU","internet_provider_name":"l37-192-166-42.novotelecom.ru","internet_provider_type":"Residential","internet_service_provider":"Novotelecom Ltd","latitude":"55.0411","longitude":"82.9344","organization":"Novotelecom Ltd","ip_address":"37.192.166.42","region":"Novosibirsk","status":"success"},"timestamps":{"created_date":"2019-01-25T17:04:11.932Z"},"_id":"5c4b418bf061e30e33bc9df0"},{"device_data":{"browser":"chrome","browser_version":"71.0.3578.99","device":"android","os":"android","os_version":"unknown","userAgent":"Mozilla/5.0 (Linux; Android 8.0.0; SM-N950F) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/71.0.3578.99 Mobile Safari/537.36"},"location_data":{"business_website":"","city":"Novosibirsk","continent":"Europe","country_code":"RU","internet_provider_name":"l37-192-166-42.novotelecom.ru","internet_provider_type":"Residential","internet_service_provider":"Novotelecom Ltd","latitude":"55.0411","longitude":"82.9344","organization":"Novotelecom Ltd","ip_address":"37.192.166.42","region":"Novosibirsk","status":"success"},"timestamps":{"created_date":"2019-01-27T03:33:45.288Z"},"_id":"5c4d2699b7d9df3016c3fcd5"},{"device_data":{"browser":"Chrome","browser_version":"75.0.3770.142","device":"Unknown","os":"Windows","os_version":"windows-10","userAgent":"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/75.0.3770.142 Safari/537.36"},"location_data":{"business_website":"","city":"Iskitim","continent":"Europe","country_code":"RU","internet_provider_name":"l37-192-166-42.novotelecom.ru","internet_provider_type":"Residential","internet_service_provider":"Novotelecom Ltd","latitude":"54.6366","longitude":"83.3045","organization":"Novotelecom Ltd","ip_address":"37.192.166.42","region":"Novosibirsk Oblast","status":"success"},"timestamps":{"created_date":"2019-07-23T06:01:53.242Z"},"_id":"5d36a2d132ce8d044d2ef637"},{"device_data":{"browser":"Chrome","browser_version":"76.0.3809.111","device":"Unknown","os":"Android","os_version":"unknown","userAgent":"Mozilla/5.0 (Linux; Android 9; SM-G950F) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/76.0.3809.111 Mobile Safari/537.36"},"location_data":{"business_website":"","city":"Iskitim","continent":"Europe","country_code":"RU","internet_provider_name":"l37-192-166-42.novotelecom.ru","internet_provider_type":"Residential","internet_service_provider":"Novotelecom Ltd","latitude":"54.6366","longitude":"83.3045","organization":"Novotelecom Ltd","ip_address":"37.192.166.42","region":"Novosibirsk Oblast","status":"success"},"timestamps":{"created_date":"2019-08-26T09:10:51.298Z"},"_id":"5d63a21babee6303bce4c61a"},{"device_data":{"browser":"Chrome","browser_version":"76.0.3809.111","device":"Unknown","os":"Android","os_version":"unknown","userAgent":"Mozilla/5.0 (Linux; Android 9; SM-N950F) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/76.0.3809.111 Mobile Safari/537.36"},"location_data":{"business_website":"","city":"Novosibirsk","continent":"Europe","country_code":"RU","internet_provider_name":"81.mtsnet.ru","internet_provider_type":"Residential","internet_service_provider":"MR Sibir","latitude":"55.0415","longitude":"82.9346","organization":"MR Sibir","ip_address":"213.87.224.81","region":"Novosibirsk Oblast","status":"success"},"timestamps":{"created_date":"2019-10-01T12:11:23.185Z"},"_id":"5d93426be6f8250345823a76"},{"device_data":{"browser":"Firefox","browser_version":"69.0","device":"Unknown","os":"Windows","os_version":"windows-10","userAgent":"Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:69.0) Gecko/20100101 Firefox/69.0"},"location_data":{"business_website":"","city":"Iskitim","continent":"Europe","country_code":"RU","internet_provider_name":"l37-192-166-42.novotelecom.ru","internet_provider_type":"Residential","internet_service_provider":"Novotelecom Ltd","latitude":"54.6366","longitude":"83.3045","organization":"Novotelecom Ltd","ip_address":"37.192.166.42","region":"Novosibirsk Oblast","status":"success"},"timestamps":{"created_date":"2019-10-18T07:15:25.665Z"},"_id":"5da9668df01fc98c8df3edc8"}],"listing_watchlist":[],"iat":1571478571,"exp":1572083371}.LEK4Sj5HlkGjHgvMj7gNHtqGuZD0ZelE_Y5VAalpoiA

I am not storing these in the DB. They only get stored in the user's local storage of the browser and are sent up to the API by Angular when a route requires authentication.

As previously stated, this issue is only occurring with the old user that I originally created with the app. Not sure why this is happening. Perhaps @mikenicholson can shed some light? I haven't deleted the old user account so I can run some tests if need be.

from passport-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.