If you're building your own authentication system, it's a really good idea to include a flag in your payloads, to indicate whether that token was generated by authenticating with user credentials, or by using a refresh token. You can use this flag to authorize sensitive operations, such as changing your password or making payments - so if the user didn't log in recently, you can prompt them to log in again for sensitive operations. I would say this is a must for most applications.
@abdulazeez.982 жыл бұрын
I’ve encountered this in some websites. Nice to know how it was implemented.
@duythinh2522 жыл бұрын
What a great information right there! Thank you for sharing. I immediately recognize the use of the flag in payload when I changing my facebook password for example, it requests me to re-enter my password again for authenticating with user credential
@aynuayex2 жыл бұрын
ya.we love to see how we can implement that.
@shahreazneeloy2119 Жыл бұрын
You have a KZbin channel. Please make a video on this topic
@mohammadalaaelghamry8010 Жыл бұрын
Thanks for the note. it helped me.
@HamKibz4 жыл бұрын
It took me only 27 minutes to understand a simple concept that has been overly complicated by some bloggers. Thanks man, that was great.
@aram56424 жыл бұрын
The single tutorial a dev should ever watch to get their heads wrapped around auth. Great pace and flow, pure English, pleasure to watch and listen to!
@SuperRockthing5 жыл бұрын
I discovered your channel 30 minutes ago and I have already subscribed. Your way of explaining things with minimum jargon and straight forward approach is so refreshing.Keep up the good work!
@WebDevSimplified5 жыл бұрын
Thank you so much! My goal with the channel is to teach the most amount of content in the least amount of time, since time is the most valuable resource we have.
@serkanakman99454 жыл бұрын
@@WebDevSimplified that is what makes you and your channel great!
@phani123d4 жыл бұрын
@@WebDevSimplified great
@raymondyoo54613 жыл бұрын
totally agree :)
@mosesegboh2 жыл бұрын
True. He is one of the best ones.
@ocoocososococosooooosoococoso4 жыл бұрын
I'm from South Korea, Kyle explains in a concise and straight plus simple easy way which makes me understand way better than Udemy courses.
@chaop4o8784 жыл бұрын
I am so close to start crying of joy. I just spent so long trying to figure this out and then I found this video. Thank you so much. Honestly, you make my favourite tutorials.
@AbidemiEnitan-t2z3 ай бұрын
Even after 4 years you made this video guy, I found it so resourceful. It just killed my fear for JWT as a complex auth method. Sometimes I just want to use just session to manage auth... Now I want to fight it and sincere with you short well explained lesson, I think it's a good start! After watching the video, I access the source code and spent almost 40 minutes to read and digest the codes, then re-watch the video again. It's really broke the fear!!
@ROCKEFELLAPRODUCTIONS5 жыл бұрын
You nailed these tutorials! I actually understand what you are explaining. You don't dilute it with unnecessary lingo in an attempt to sound smart. Thank you!
@tinnyw23 жыл бұрын
Kyle has an amazing talent for teaching and this demystifies a lot of how to implement JWTs on the server end. If I may, one caveat I would add is adding access and refresh tokens in the body payload may be prone to being stolen in an XSS attack and depending on how secure you would like to make your site you might want to instead store them on http-only & secure cookies with a samesite set to at least lax so they're not read by Javascript and easily stolen. Again, this tutorial is on point on so many levels and amazing!
@heysisteronion2 жыл бұрын
Do you have any solution for that? Thx
@AlanJoelSchneider6 ай бұрын
@@heysisteronion Store tokens in cookies with http-only, secure and same-site
@majoulwa4 жыл бұрын
Hi, I would particularly like to praise your clear explanations and your super clear pronunciation. So it is very easy to understand, even for someone like me, who doesn't have a lot of experience in English and who often has trouble following English-language content with a strong accent. Really great!
@samgram51224 жыл бұрын
You blink a lot, but holy crap! You speak so clearly and teach so well without any cuts! AMAZING! Thank you so much!
@CodeDreamer683 жыл бұрын
Thanks for keeping it simple! You are living up to your name. I watched 5 other jwt videos from well-known vloggers, and was still left confused. This one was spot on. I get it now. Thanks!
@AwkworldStudios4 жыл бұрын
Thanks for making this! Fun fact for anyone else watching: you can configure dotenv from your package.json scripts so that you don't have to write require in every file by using the -r flag and dotenv/config like so: "scripts": { "dev": "nodemon -r dotenv/config index.js" },
@vinaydixit834 жыл бұрын
Everything is good. But i would suggest you to be little slow when you do the code.
@dheerendrapratapsingh94066 ай бұрын
I come to your channel to learn one thing and most of the time I learn 2-4 new things for sure.. Thankyou..You are one the best teachers..Love from INDIA..🇮🇳🇮🇳🇮🇳
@PaweAndruszkow3 жыл бұрын
this is how code tutorial video should look like! Simply, precize, no overtalking, just exact content we need, very good job!
@mykolakecha3 жыл бұрын
This is probably the first time I'm writing a comment to a video. The reason - just wanted to acknowledge the quality of content. Especially how nice & simple everything is explained.
@drteeth115 жыл бұрын
Yoooo, I just found your channel this week and wanted to let you know I love your content. Super informative, clear explanations, all around great videos. Keep up the good work!
@WebDevSimplified5 жыл бұрын
Thank you so much! I hope my future videos are just as useful.
@BrunoWinck5 жыл бұрын
same :) feeling very lucky
@XiagraBalls3 жыл бұрын
Your tutorials are some of the best on YT and I watch a LOT of programming tutorials! 👍🏻👍🏻👍🏻👍🏻👍🏻 🌟🌟🌟🌟🌟
@SaadShah11333 жыл бұрын
I tried to implement JWT by watching different tutorials but i couldnt understand it, your video was the only video i understood, best node js videos keep it up; great work
@Cooldude-qj9yb6 ай бұрын
00:02 This video covers JWT authentication using Node.js and Express in two parts. 02:04 Creating and running a server using Node.js and Express 06:04 Implement JWT authentication in Node.js 08:01 Generate random access token and refresh token secrets. 11:46 The video discusses the process of verifying and authenticating a JWT token. 13:40 JWT authentication is working properly and allows users to access their own posts 17:31 Refresh tokens are used to invalidate stolen access and separate authentication and authorization servers 19:12 Create a refresh token to handle token expiration 22:31 To create a new token, the refresh token is stored in an array. 24:19 Implementing JWT authentication and managing access tokens
@number1neek4 жыл бұрын
Great video as always! Just wanted point out that what's being covered here is called authorization, not authentication. Authentication is when you confirm a user's identity and authorization is giving that user access to parts of the website
@lahiruudayanga59895 жыл бұрын
Damn this is amazing. Wasted 4 hours watching shitty videos and then came through this. Just 30 mins and everything well explained on point. Thanks a lot bro. You got a new subscriber!!!
@WebDevSimplified5 жыл бұрын
Thank you so much!
@quietnix3 жыл бұрын
Man, this is the most efficient tutorial on the topic. Where is your applause button dude.
@rajeshjamnadas5 жыл бұрын
No nonsense just straight to the point. Clear and precise explanation. Thanks you for time for a good tutorial, cheers!
@lordrampenthump4223 жыл бұрын
Its really hard to explain how valuable this channel is to me. Thank you for existing
@ni_kabiu_john Жыл бұрын
Who said pretty men can't code... man thanks sooooo much for this.. i 'have been afraid of backend dev, but now i learning smoothly..
@brianchandler33463 жыл бұрын
The absolute clearest tutorial I've ever seen on the topic. I wish I had found this earlier.
@CAPS_AMERICA3 жыл бұрын
This is the cleanest for me: kzbin.info/www/bejne/j6DGg6RjgMqmea8
@VishalKumar-dv6qj3 жыл бұрын
Everything was straight-forward and on-point. One question arises - Why we need to create a refresh token when we can delete the previous access token when user logs out? In that way he will not be able to use that access token forever
@ryanlarge62962 жыл бұрын
Thank you Kyle for another great video!! Especially by making some confusing topics much clearer and understandable in such little time. I think that many of us could benefit a thousand times more from this jwt knowledge if you created a sequel to this video, or even simply a separate video all together explaining how this backend logic is tied in with the front end via a js framework or keeping it simple like ejs or regular html. There is not a whole lot of good quality educational videos or documentation covering how it can all be connected and implemented into a true fullstack application. It took me a very long time to figure out how to serve my front end as well as authenticate users with jwt using ejs. I would love to see a good video on this from you. Thank you again!
@jonnjon12 жыл бұрын
I spent days trying to implement this with passport and didn't succeed. But with your help, I managed to do the same in a couple hours , Thanks a lot!!!
@garrafromsand4 жыл бұрын
Very distinct skill of explanation, could not be more lucid than this, 2 days of here and there in 20 min
@divyanshubhatnagar46014 жыл бұрын
Have to say this was short and loaded with information. I really liked the part where you also explained the Auth and Resource server. Really appreciate the content :)
@aubz99244 жыл бұрын
Kyle, it would be amazing if you could make a video on how to handle JWTs on the client-side, particularly in React, in order to close the loop on this topic. As always, awesome video :)
@aspected4 жыл бұрын
I second this! I think Ben Awad made a video about that but doesn't go into much detail
@robertjif63374 жыл бұрын
I want to see this too, wanna know if what I'm implementing is actually correct
@Robd5154 жыл бұрын
Funny, I'm coming to this video because I know how to implement it with React and not without it. I learned through Brad Travery so you may want to look through his videos.
@doberman73 жыл бұрын
@@Robd515 could you share an URL?
@adityanair35663 жыл бұрын
@Kyle, please see this comment! Awesome work man, you are giving immense value to society.
@Bananabanananax6 ай бұрын
11/10 video. I just implemented this for a rock climbing app i'm creating. Tomorrow I will figure out how to manage the keys in my database rather than in the program.
@qintotgroup2 жыл бұрын
Where have you been all my life Bro. --- THANK YOU for making my job eaaaaaaasy.
@Bruno87198 Жыл бұрын
Exactily what I need! You just got a new subscriber. Simple, direct to the point, no use of database and other things, really direct to the point! Saves a lot of time. Thank you!
@avivshvitzky24595 жыл бұрын
I still have some stuff that isn't clear to me, but you probably won't see my message, so i'l just say that you are an amazing teacher, you really have a skill in that area!
@WebDevSimplified5 жыл бұрын
Thanks! I have another video on JWT that explains JWT in depth you may want to checkout.
@avivshvitzky24595 жыл бұрын
@@WebDevSimplified I think my biggest question is how the refresh token isnt prone to stealing as the access one
@persnlassname71374 ай бұрын
I wish I could write codes from scratch like you and explain things that clearly. Good content! 👍
@pprathameshmore4 жыл бұрын
Kyle is a really good teacher. His tutorials helping me a better developer.
@ghilmanfatih97513 жыл бұрын
certified beginner-friendly enlighten my noob jwt knowledge in less than an hour
@spetsnaz_24 жыл бұрын
Man! every video of yours are most simplified on the web one could ever find.....Great work
@juanetehOK5 ай бұрын
i was looking for one day some simple explanation like this for jwt usage, thanks a LOT!
@scigama713 жыл бұрын
i echo the sentiment that i have learned more with this video then reading books for hours.. Well done :)
@nejitawo96574 жыл бұрын
In just 30 mins i've learned what a ton of books couldn't explain clearly.
@juraev00564 жыл бұрын
You must be reading a wrong book
@hagenlens14034 жыл бұрын
@@juraev0056 Probably
@snoowwe4 жыл бұрын
Sometimes you just need to see it in action to understand it. I learn math better by example than by reading theory.
@jawad97574 жыл бұрын
Is reading books about programming a thing? I mean it would be good for something like assembly or c or c++ but defo not for anything that is related to js
@juraev00564 жыл бұрын
@@jawad9757 I think it is good to read about best practices and design patterns regarding any programming language
@farisfajar69823 жыл бұрын
Thanks youtube for recommend this channel. I just started to learn programming two weeks ago and find your channel. It is great content for me even i still did not really understand it most of the part so i need to learn a lot from the scratch.
@krunalchauhan57804 жыл бұрын
When I feel to buy any paid course then your video motivate me to save my money ❤️
@techable75245 жыл бұрын
Superb tutorial, video and sound! It's rare to find such quality. Subscribed and looking forward to more of your content.
@WebDevSimplified5 жыл бұрын
Thank you so much! I hope the rest of my videos are just as helpful.
@raisedbyreels3 жыл бұрын
Yeah, I appreciate tutorials like this, a perfect blend of explanation and implementation. Thanks a million!
@PyroManZII4 жыл бұрын
Your channel is incredible and so informative! I clicked on the video to learn the best way to handle JWTs and in the first couple of minutes I am already learning about all these different things I didn't even know I didn't know. Do you happen to be an educator at all? It seems like you would be a great lecturer or teacher at a Uni or College.
@WebDevSimplified4 жыл бұрын
Thank you so much! I am not a professional educator. I have been offered a job as a University professor before, but I love teaching online so I turned it down.
@santhanamelumalai80254 жыл бұрын
Thanks for the video, I never saw tutorial video without skipping its part, but you broke that with the great way of story telling. Very helpful video.
@JeremiahJones-j1f Жыл бұрын
Excellent video. Probably one of the best explanations I have seen. Also, fast - in a good way.
@SavijCoder Жыл бұрын
I know this is kind of older, but great presentation, very clear! I have a similar video for doing this in c# (also pretty old), but love how you explained it all here. Thanks!!
@jungminkim3132 жыл бұрын
quick tip for people struggling with the request.rest file... there should be no line between the request and the header, but there should be one line between the header and the body. I was confused because I'd never been in a situation where the blank lines really mattered but... it does here.
@natyragashi9822 жыл бұрын
Thank you man, you are one of the rarest who gives real solutions
@princebillygrahamkarmoker21223 жыл бұрын
Best tutorial on JWT token. You are straight forward and that's why I have already subscribed to your channel.
@denibegaj45644 жыл бұрын
Thanks, coming from the world of ASP.NET this was piece of cake. Dudes over there make it look like rocket launching, when it actually is a very simple mechanism.
@raicubogdan8078 Жыл бұрын
i love how effortless and efficient you explain everything. and all the tools you use are really cool and easy to setup. thanks!
@scu8a3 жыл бұрын
Thank you for the quality tutorial. You're clear-spoken, and just the right speed for learning. At one point, I thought "This guys IQ must be over 140" - BTW, this is the first video of yours I watched. I found this video when I did a google search for "web token authentication". Again, very nice work.
@michelkazi31125 жыл бұрын
I'm using sails JS and their documentation is a hit or miss with a lot of things. They also have support for sessions instead of JWT. Your explanation and walkthrough were so nicely made that I was able to translate the logic of signing and verifying JWT into helpers for my project. Thank you!
@nithigd10143 жыл бұрын
Thank you for explaining complex concepts in very simple and straight forward way I watched many of your videos and I learnt a lot of things that no body could teach in 1 video but you are way of explaination is awesome, you are one of the best teacher in the universe, thank you so much :)
@buhlemwanza6323 жыл бұрын
God Bless you man, this is great within 30 minutes JWT and auth isn't mystery anymore, keep it up, you're going to help a lot of people. God Bless you!
@zachwhite80545 жыл бұрын
Dude you might be my favorite web dev channel at this point. Massive Traversy fan and I also like Academind but damn this stuff is good
@johnnydriesen75755 жыл бұрын
Same here :)
@MariaSantos-em5jv4 жыл бұрын
He explains things very well and at a nice pace.
@Tibo4373 жыл бұрын
Thanks a lot from France for your video, this is so simple doing things with your explainations, please never stop ;)
@solofaxum4 жыл бұрын
Bro you are the best. That is all I can say. you simplify the complex. ...keep it up.
@dragmove4 жыл бұрын
This video is perfect for me to understand a concept of JWT token and refresh token. I really appreciate it. Thanks Kyle. :)
@codeforlife95134 жыл бұрын
Kyle your video inspires me to learn more...and makes easy to understand all the aspects. Thank you so much.
@mayank_upadhyay_194 жыл бұрын
Let me tell you that it was complicated, but after watching few times, I got the concept and implementation.
@haha-eg8fj4 жыл бұрын
That Rest Client plugin is so useful! Works like a charm.
@winken26663 жыл бұрын
I am very grateful for this tutorial, thank you! My hobby project is one step closer to not being a hobby project.
@AbhishekKumar-vl3cb3 жыл бұрын
Have a good day you too...👍🎊 You just SIMPLIFIED my WEB DEV query in few minutes... ❤️🙏
@lautaro33654 жыл бұрын
Dude this was the best video I've seen about JWT and how easy you made it to implement.
@ozzyfromspace3 жыл бұрын
This was a highly informative video and I’ve gotta say, I learned a ton watching you code this up! I do have a minor point of contention about the refresh token though.. you created the refresh token without an expiration date, so what’s preventing me from just using that on your 3000 server indefinitely? Hope someone can lend their perspective to this question :) Again Kyle, FABULOUS EXPLANATION! 🥳
@namminb61012 жыл бұрын
I think he made a mistake .. if someone gets the refresh token, they can use it to indefinitely generate new access tokens. The issue is not even that, the issue is that the reason we are using refresh token is so we can later invalidate it (allow user to logout and remove the refresh token from database), the issue then comes, if the user logs in again, the same exact refresh token (that the hacker already has) will be created again (since all inputs are the same), and the hacker can now continue generating access tokens, defeating the whole purpose of refresh tokens. I think either an expiry date or some other dynamic value should be added so that we create a new different token when a refresh token is invalidated (deleted from database).
@debmallyabhattacharya43945 жыл бұрын
This lives up to its name. Truly simplified. 💙
@lucaslorenzo62492 жыл бұрын
this is amazing, the way you explain all this concepts make it look easy
@JamesQQuick4 жыл бұрын
You're the JWT mastermind :)
@aynuayex2 жыл бұрын
great content.since the video is outdated and also you are handling the refresh token manually(u are getting the refresh token through a post request not from the client directly) and does not have expire time,also we like to see how we can implement in react and also with the passport-jwt.we need updated new video on this since you are good at time.ya u deserve 1m subscribers.
@dericbytes Жыл бұрын
I always pick up something new from your videos. Thanks
@sarahwang-h9x Жыл бұрын
Thank you very much, Kyle. Your video helped me find a job. Thanks for sharing.
@MrVipulLal11 ай бұрын
Your videos are always brilliant. A big 🙏
@joicyjoy96583 жыл бұрын
Kyle.....You are a gem for developers....
@LithiumFireX2 жыл бұрын
Hello Fireship, I love your 100 seconds videos.
@pranjalsinghkatiyar4972 Жыл бұрын
hey Kyle its good to see such a clear and refined video from backend side ... but could you please make a video explaining how client side uses the Refresh and Access JWT.
@DoubleDYouTube3 жыл бұрын
This video cleared up a lot of things regarding JWT. Thanks a lot!
@alexanderzharkov69533 жыл бұрын
Thank you, Kyle, for this informative content. I filled many gaps watching your videos and following your advices
@AndreFreitasTech2 жыл бұрын
You have won a subscriber! Good content, thank you for sharing!
@shambashibmajumdar12683 жыл бұрын
Amazing! Your content always fascinates me and I learnt many things from you man!
@armaandhanji21125 жыл бұрын
I LOVE anything you make related to Node.js. Thanks always
@WebDevSimplified5 жыл бұрын
Thank you! I'm really glad you enjoy my node videos because I love making them.
@mokroargra72774 жыл бұрын
Nice video man, just found your channel. You explain things very well. I didn't have any trouble following what your doing.
@random24026 ай бұрын
Thank you bro for this amazing content. Just clean content, no bullshit. Thank you so much.
@OwaisAhmed-j8n Жыл бұрын
u r a great teacher .... u r making my career
@eneomaos332 жыл бұрын
You have no idea how long it took to get this working, not your fault lmao. Thank you!
@chronosoutoftime4 жыл бұрын
this is a very good starting point, but in my opinion it misses some parts: - first if the client refreshes, since you are not persisting the refresh token anywhere it will need to login again, and this can be fixed by storing it in a httponly cookie which is still vulnerable, - second the client part is completely missing, i know the purpose of this is to keep things simple, but then ppl needs to do real stuff. probably the refresh requests should be sent little before the accesstoken expires. - the array of refresh tokens or the db where you store them, means that we are not differing too much from usual session management which is opinable. Anyway, yours are very great tutorial, i am wondering what tools you use for registering videos
@daniloespinozapino48653 жыл бұрын
You did a really good job with this video dude. Simple and clean.
@nabiisakhanov35225 жыл бұрын
Darn it Kyle, I get shocked every time I see you fixing mistakes in the code without a delay of thinking. I wonder if you make those typos on purpose to show people a few common ones, or you are just so good at coding you already know what's wrong as soon as you see an error :D
@WebDevSimplified5 жыл бұрын
Sometimes I make mistakes on purpose but usually it is an honest mistake. Many times I edit out the pause that I take to fix the error though. I generally take a bit of time to find and fix my bugs.
@nabiisakhanov35225 жыл бұрын
@@WebDevSimplified oh, I see :) Whatever, your skills are very impressive still, and all the knowledge you share with people for free is just so precious for the webdev community. Personally I am going through my intership right now and it sometimes consumes a lot of time to find a reliable tutorial on some technologies. Your channel provides a big help here :) will consider becoming a patron next month
@WebDevSimplified5 жыл бұрын
@@nabiisakhanov3522 Thank you so much!
@igors12084 жыл бұрын
The greatest video about jwt implementation on node i've found at internet! Thanks a lot!
@ShreeMamadevji2 жыл бұрын
Very Good explanation Brother u are looking like Paul Walker of fast and furious
@vladstanciu59234 жыл бұрын
Really nice video, i just leared all I needed to know about jwt in order to use it in my project. Thanks a lot dude! Really big thumbs up
@ashuthe1 Жыл бұрын
This Person is gem for developers :)
@BruceArmstrong091219974 жыл бұрын
Owow I just realised I clicked like button while watching just like natural action I never like most videos I see in general I must have instinctively like your videos!