Node.js API Authentication With JWT

Поделиться
HTML-код
  • Опубликовано: 3 янв 2025

Комментарии • 448

  • @RealToughCandy
    @RealToughCandy 7 лет назад +195

    Thank you Patreon patron for this request and thank you Brad for the tut!

    • @TraversyMedia
      @TraversyMedia  7 лет назад +15

      You're very welcome. Great channel by the way, guys check it out

  • @aiwithrudiyt
    @aiwithrudiyt 4 года назад +6

    Brad comes along to save the day once again. Honestly bro I don't know how you do it.. 5 days of pain, dozens of videos and dozens of blog posts with unclear non-relevant over engineered information, then you come along and in one fell swoop answer EVERY SINGLE QUESTION I had around the topic in a clear, detailed and swift manner. Thank you brother once again...

  • @emmanuel4699
    @emmanuel4699 7 лет назад +148

    You're a role model to us all. I plan to improve my Patreon participation this coming year. I've grown in confidence as a software dev and have a job now thanks to your videos. Overall my life has seen a lot of improvement as a result of this channel, So thank you and Merry Christmas, Brad.

    • @TraversyMedia
      @TraversyMedia  7 лет назад +13

      Thank you, Merry Christmas to you as well :)

    • @Zawodowieec
      @Zawodowieec 4 года назад

      Great to hear buddy, hope you're still doin' well :)

  • @chriszhang3629
    @chriszhang3629 6 лет назад +3

    You are not the only one who makes video about JWT, however, you deliver the knowledge in clearest and easiest way. Thank you Brad!

  • @desbutler4257
    @desbutler4257 5 лет назад +7

    One of the shortest, yet most succinct, useful tutorials I've seen. Brad rocks!

  • @nehascorpion
    @nehascorpion 4 года назад +3

    I always struggle understanding the auth stuff but you have managed to explain it so well. Thank you so much for this tutorial Brad!

  • @keyone415
    @keyone415 4 года назад +24

    In 2020, with v12.15.0 everything still works exactly the same, I just run through your tutorial. Thank you Brad!

    • @AnonymousDeveloper1
      @AnonymousDeveloper1 4 года назад +1

      That's good, because I'm going to do this tutorial soon.

  • @jaboyak
    @jaboyak 7 лет назад +2

    This is exactly what I needed. Short, sweet, and to the point! Have a great holiday, man!

  • @adriatic123
    @adriatic123 5 лет назад

    I needed a refresh about JWT functionalities and this little course was very helpful. Just one mention. Token name that we send with res.header can be anything for example 'auth-token', not just 'Authorizatiion'. And token value in a name-value pair doesn't have to start with 'Bearer' word, it's enough to send token only. In that case we do not have to split result into name 'Bearer' and token value.

  • @thexs1118
    @thexs1118 7 лет назад +17

    I was literally just looking up how to do this and this video pops up. This video is a God send lol. Perfect timing.

  • @nosferathu258
    @nosferathu258 5 лет назад +2

    Reaaaaaly liked the straightforwardness of the tutorial. Implemented it on an existing server in under 40min thanks to your tutorial, keep up the good work :D

  •  5 лет назад +1

    I came from the MERN series part 9 to learn more about JWT before implement it to the project. And I made it even it is my first time using auth. Thanks, Brad. 👏🏽 Excellent content as always!!

  • @datapro007
    @datapro007 2 года назад

    Brad, your videos are amazing. Whenever I need to cut through the b.s. and learn something quickly, I come to your channel. This video is an enormous help to me. Thanks!

  • @edward481
    @edward481 3 года назад

    This is an excellent, no-nonsense, straight-forward explanation of using JWTs to protect API routes, thanks.

  • @devonmarantz3324
    @devonmarantz3324 5 лет назад +1

    Thank you so much! I’ve been struggling trying to make a protected route with passport for the past month. I couldn’t get it working on a side project I was working on would get super frustrated. I watched this video last night and was able to get it working today! You are a God send! 🙏🏽

  • @Somsubhra_Das
    @Somsubhra_Das 5 лет назад +2

    Man I love this tutorial... Other RUclipsrs take more than 1 hr to explain just this. But you did it in less than 25 mins..

  • @g10-you
    @g10-you 7 лет назад

    Don't dislike knowledge. Knowledge can be appreciate only. It's not a movie which can be like/dislike. Humble request to the people. Brad I really appreciate your knowledge which improve my understanding and skills. Thank you Brad for this fantastic tut.

  • @shashanksshetty9870
    @shashanksshetty9870 7 лет назад +10

    Merry Christmas Brad. I wanted this video badly. I was stuck with server side route authentication. Thanks for it and keep the good work going 😊. If possible please make a video using front end application, so that we will get more clear cut idea on this.

    • @Baal93Ash
      @Baal93Ash 4 года назад

      yes please, agreed !

  • @NaveenKumarasinghe
    @NaveenKumarasinghe 3 года назад

    Probably the best JWT tutorial on the internet.

  • @ajit555db
    @ajit555db 5 лет назад +1

    Brad Bhai (brother in India), thanks a lot for the succinct explanation..always love the explanation in code.

  • @alexn2566
    @alexn2566 5 лет назад +35

    You could have handled the JWT verification in the middleware, to keep responsibilities nicely separated. Other than that, nice tutorial :)

    • @morphman86
      @morphman86 4 года назад +2

      That also gives the nice advantage that the token itself doesn't get passed on the request object twice (req.token = bearerToken is no longer required).
      May not seem like much, but if you ever need to scale an application, even a few bytes of data per request can save a lot in the long run.

    • @martinmendez695
      @martinmendez695 3 года назад

      Yes.
      The authentication should be done at the middleware.
      What Brad did works better for authorization once in the route handle.

  • @GeekMustHave
    @GeekMustHave 7 лет назад +1

    Merry Christmas to you and your family. You have been a big help and inspiration over the last year. I appreciate you and the extreme effort you put into helping people to learn. As always keep broadcasting!!

  • @Koyi_supremacist
    @Koyi_supremacist 3 года назад +1

    october 2021 still works!
    thx brad

  • @haroldcrane1595
    @haroldcrane1595 4 года назад +3

    This is the course I've been looking for! Brad, you are the best!!

  • @mohammedabdel-baki7253
    @mohammedabdel-baki7253 3 года назад

    Clear & to the point without irrelevant information.
    Thanks Brad you've been helping me so much for almost a year.
    Cheers 🍻

  • @jazzpote4316
    @jazzpote4316 4 года назад +6

    17:57 Beware: do not store JWTs in LocalStorage. Use an http-only cookie instead. Any javascript has access to locastorage, therefore by using it as your secure storage you lay your app open to xss attacks.

    • @TheAndre2131
      @TheAndre2131 4 года назад

      Well, localStorage is generally the preffered method. Moreover cookies are not any safer, they are prone to CSRF attacks as well

    • @jazzpote4316
      @jazzpote4316 4 года назад

      @@TheAndre2131 Yep, that's why we invented CSRF tokens!

  • @danielkimani5431
    @danielkimani5431 7 лет назад +1

    I have been waiting for this Brad, I can't thank you enough

  • @Tanzeel431
    @Tanzeel431 4 года назад

    Best video on node and jwt so far. Thanks a lot.

  • @BlakeEdwards333
    @BlakeEdwards333 6 лет назад

    Best technical videos on youtube, keep up the good work!

  • @arpitagrawal7771
    @arpitagrawal7771 5 лет назад +1

    I have seen two of your videos and found this channel very helpful. Thank u :)

  • @hardikjhamb229
    @hardikjhamb229 4 года назад

    thanks its really helpful video, my boss was struggling with this authentication for a very long time, but now we will prove that who is the boss

  • @kirillfishuk5553
    @kirillfishuk5553 4 года назад

    Very useful even after 3 years! Thank you Brad!

  • @vidalroland
    @vidalroland 6 лет назад

    This is exactly what I was looking for !
    Now I know how to make it work. Clear and simple.

  • @ЕгорЗахаров-д4й
    @ЕгорЗахаров-д4й 4 года назад

    Awesome! I wish each my question on the Internet had such a clear explanation

  • @muhammadyasirjaved6377
    @muhammadyasirjaved6377 4 года назад +1

    Simple, To the point and concrete. Thanks Buddy!

  • @bouidiaabdelrahmene1617
    @bouidiaabdelrahmene1617 6 лет назад +1

    I am a huge fan of your tutorials, thank you so much for all these great videos

  • @slicerabbit6166
    @slicerabbit6166 5 лет назад +2

    you shouldn't store the jwt in local storage, as it opens an attack vector for xss. an httponly cookie is the preferred way. now, it means that your rest api no longer is stateless, but it sure makes it way more secure.

  • @Juz3000
    @Juz3000 6 лет назад

    You have some of the best web tutorials I've found yet. I bought also your Udemy MERN stack course, can highly recommend! Thanks.

  • @jorgerenteral
    @jorgerenteral 5 лет назад +3

    The verifyToken middleware should do the token validation and, in case of, check the token is valid from the DB.

  • @billkariri
    @billkariri 5 лет назад +1

    I found this video at the right time, thanks Brad

  • @psychonighty3076
    @psychonighty3076 4 года назад

    That was a huge amount of help , really easy to understand and you explained it in a calm , quite and nice manner which is really important

  • @kedarnadkarny4718
    @kedarnadkarny4718 7 лет назад

    I implemented this 100% successfully. Thanks, Brad.

  • @gulfcoastflyfishing8458
    @gulfcoastflyfishing8458 6 лет назад

    Doing the lords work. Thanks a bunch, this just helped me through the toughest part of my current project.

  • @devlondres
    @devlondres 6 лет назад +1

    Thanks for recording this video. Things are a lot clearer now.

  • @2wheelsonline
    @2wheelsonline 7 лет назад +1

    I love watching your tutorials and this is brilliant. Many thanks!

  • @nhulongctk10
    @nhulongctk10 6 лет назад +23

    Why do we need the Bearer string in the authorization? instead of header['authorization'] = '' ?

    • @xNameless
      @xNameless 5 лет назад +45

      There are different types of Authorization, such as Basic, Bearer, Digest, HOBA, OAuth - even Amazon Web Services has one called AWS4-HMAC-SHA256. The idea behind it is allowing multiple ways of authenticating with the same API, or server. This dates back to the HTTP/1.0 standard from W3C :)

  • @neoskribe8986
    @neoskribe8986 7 лет назад

    Thanks Brad, great video, happy holidays.

  • @imjustnobody6893
    @imjustnobody6893 3 года назад

    now i understand jwt and how to use it... thanks Brad!

  • @sabinhertz4145
    @sabinhertz4145 4 года назад +1

    This video was very well done, very informative, and exactly what I was looking for.
    Thank you, I learned much more than I bargained for.

  • @safwanmohammed7715
    @safwanmohammed7715 5 лет назад

    Very nice explanation with working code examples

  • @Xero1216
    @Xero1216 6 лет назад

    Thank you, i learned how to use a token to access protected routes. LOVE IT MAN!

  • @DebugWithAdam
    @DebugWithAdam 3 года назад

    Great work helping the community in a short video with excellent and straight forward professional explanation.

  • @MrMarcel43055
    @MrMarcel43055 4 года назад +2

    14:04 you could also do: const [,bearerToken] = bearerHeader.split(' ');

  • @urbanmunda2451
    @urbanmunda2451 4 года назад

    Really great explanation sir... Simple and worthy ...

  • @stringedstories823
    @stringedstories823 3 года назад +1

    This is exactly what i needed, amazing stuff!!!

  • @belscode3941
    @belscode3941 5 лет назад

    Thank you brad for this awseome tutorial , just a note we should send only the id in the payload as far as read in articles

  • @rp962
    @rp962 6 лет назад +1

    Well, this is one of the breakthrough demos of oauth present in youtube. Great job man.

  • @youssef_houmazen
    @youssef_houmazen 3 года назад

    thanks traversy, such a legend for me and an inspiration...

  • @varolo74
    @varolo74 6 лет назад

    Thank you from Italy, very clear and helpful!

  • @leeyahav4754
    @leeyahav4754 6 лет назад +7

    does it will be better to move "jwt.verify(....)" to the middleware function ???

  • @aldobangun223
    @aldobangun223 3 года назад

    Very clear explanation. Thanks Brad.

  • @adamcrap
    @adamcrap 6 лет назад

    Awesome stuff brad as always!

  • @peter11612
    @peter11612 4 года назад +2

    Thanks for the video, clear and easy to understand!

  • @MrXmen262
    @MrXmen262 5 лет назад +1

    Thanks Brad , I hope that you do a full mean stack project

  • @alexcharlton2316
    @alexcharlton2316 6 лет назад

    Great tutorial, clear & simple to follow!

  • @akshayshelke5833
    @akshayshelke5833 5 лет назад

    A very nice tutorial sir , you r a role model for all of us , thank you sir !!

  • @R3n3gad399
    @R3n3gad399 7 лет назад +1

    @Brad you were stripping Bearer in api, but you also added that in postman. Is it a convention or does it throw an error if we don’t include Bearer in header.

  • @gk0r
    @gk0r 6 лет назад

    Excellent video. Short and to the point. Thank you for not building a client and using PostMan instead.

  • @rupinderkaur304
    @rupinderkaur304 5 лет назад

    Sir really awesome video. Made me understand completely about jwt

  • @KingTMK
    @KingTMK Год назад +1

    In a lot of videos I see req.headers["authorization"], but why not just type req.headers.authorization?

  • @guyfrompei
    @guyfrompei 6 лет назад +1

    Very informative and easy to follow. Thanks!

  • @tusharmaurya1668
    @tusharmaurya1668 4 года назад +1

    This is exactly what i was looking for!

  • @javidking63
    @javidking63 3 года назад

    you saved my day ! again!
    thank you brad!

  • @gicharu
    @gicharu 5 лет назад +1

    Thank you so much for your tutorials. They are very informative. You are an inspiration to us all. Could you do a refresher for the PostresSQL tut?

  • @K-Raman
    @K-Raman 4 года назад

    Great video but for who already know why jwt is needed and has theoretical knowledge of token👍❤️👌🥳

  • @degraphe8824
    @degraphe8824 5 лет назад +1

    Hi Brad
    so I came accross and article that said storing JWT tokens in localstorage is a terrible Idea... since it is sensitive data
    and I'm thinking of incorporating it in my react ecommerce app I'm building...
    I just want to know how you feel about that point?
    Thanks in advance for your kind response

    • @dylaninfinity9756
      @dylaninfinity9756 5 лет назад +2

      Clement Osuide I’m not Brad or a Software Dev, just a CS student. However, JWT tokens are unintelligible without the secret key that should only exist on the server side. And you should always implement a method to refresh tokens after they have expired at which point you are doing another check. That part wasn’t really covered in this video though.
      Anyway, storing you token on the client side for the duration of the session should be fine. I’m not sure if there is some issue specifically with localStorage vulnerabilities though.
      I’m also aware one of the benefits of JWT is unlike standard sessions there isn’t any need to store the JWT on the server usually you would save session information.
      There is a great explanation by Web Dev Simplified that goes into explanation of everything about JWT vs regular sessions and he has a separate implementation video that goes into implementing a refresh token if you’re curious.
      I’m sure with Brad being a web developer he could probably give you a more relevant and specific answer than I could. Hopefully, that’s something for the time being though.
      Edit: You can encrypt JWT tokens with JWE though it sort of defeats the purpose of having them. JWT is in fact not encrypted by default and is only base64url encoded. So, is pretty simply to decode. Therefore, as you mentioned a big problem is going to be XSS attacks when you store the JWT on the client side. Therefore, essential user information shouldn't be within the JWT payload and other methods should be used to handle XSS through JWT.
      When using JWT there is no workaround and the client must have the JWT stored on their side to allow the server to verify the client request, which means it's open for XSS attacks eherther you choose localStorage, sessionStorage, and so on..
      Generally, JWT is really good for integrating with native mobile apps (nothing needs to change on the server) and it is easily scalable because unlike sessions tokens aren't stored on the server and to add a server one only needs to include the secret key.
      In conclusion, unless you are well-versed in creating XSS protection or want to go through the research process of adding other authentication methods to secure your web app I would not recommenced JWT. It is unlikely you will need to scale your personal app to multiple servers and even in that event it probably won't be more than a few. So, one of the primary benefits of JWT is lost for a smaller-scale personal web app. Implementing JWT for demonstration purposes is always fine though. But, for smaller-scale personal web apps session based authentication is probably the way to go. Since, the user isn't stored in the paylaod XSS attacks isn't much of an issue and while CSRF attacks are opened there are widely available methods of dealing with that.

    • @dylaninfinity9756
      @dylaninfinity9756 5 лет назад +1

      "you shouldn't store the jwt in local storage, as it opens an attack vector for xss. an httponly cookie is the preferred way. now, it means that your rest api no longer is stateless, but it sure makes it way more secure." -another comment made by someone else

  • @divyanianerao5205
    @divyanianerao5205 3 года назад

    Woww this cleared my all the doubts. Thank you so much ❤

  • @_thesenator
    @_thesenator Год назад

    5 years later…. Still gold

  • @DerJP
    @DerJP 7 лет назад +28

    One suggestion: Wouldn't it be more convenient to verify the jwt in the middleware and then attach the authData to the req object? This way you wouldn't have to verify the token in every route that you define. :)
    Otherwise, as usual, awesome tutorial, have a great great holiday!

  • @norrisdamianus5250
    @norrisdamianus5250 6 лет назад

    very good, simple and clear tutorial

  • @Dinesh-ql1ok
    @Dinesh-ql1ok 6 лет назад

    Congrats 🎊 Brad for 500k subscribers ✌️👍👏🎈🎁💐

  • @EliSmith
    @EliSmith 6 лет назад +6

    The way you did things makes little sense, you should have put the jwt.verify() function in the verifyToken() function and then set req.user equal to the return of that, that would make much more sense in the long run and would keep you from rewriting this for every endpoint. Also why use 'bearer ' as the auth header and not just set it to auth: ?

    • @secret8485
      @secret8485 6 лет назад +3

      tools.ietf.org/html/rfc6750

  • @exapsy
    @exapsy 6 лет назад

    I love you. Thanks so much for the video. Crystal Clear in all aspects and I got the exact and even more information I needed.

  • @LongqiZhang
    @LongqiZhang 6 лет назад

    Make things pretty clear. Simple and Clean. Thanks.

  • @ajedittsz
    @ajedittsz 6 лет назад

    Where to store secretkey in server side? Is it in db then for every protected api request I have to access db?

    • @djBulba
      @djBulba 6 лет назад +1

      Use a config.js file to store the secret keys

  • @tigranavagyan5922
    @tigranavagyan5922 2 года назад +1

    Thank you SO MUCH for your lesson. It really helped me a lot!!!

  • @dgdev1024
    @dgdev1024 6 лет назад

    Thank you for this! I can expand upon this and save a good few lines of code and a dependency with it.

  • @nimasoufiloo2626
    @nimasoufiloo2626 6 лет назад

    Perfect video as always. short and useful.

  • @binayakgshankar9188
    @binayakgshankar9188 5 лет назад +1

    Wonderful tutorial. Please make a tutorial on Node+Express+Angular+JWT+Socket

  • @cesarp6761
    @cesarp6761 6 лет назад +1

    dumb question.. is there any difference on saving this into a cookie instead of a header? that way avoids doing all the appending on the client request and the splitting on the server? as the cookie will 'go for the ride' on each request?

  • @aminukano_
    @aminukano_ 6 лет назад +1

    Hi Brad, what is the recommended token expiry period according to best practices?

  • @kazz94
    @kazz94 5 лет назад +3

    Your explanation was perfect. Thank you so much!!
    You have my like and my sub :)

  • @evangeloskolimitras5276
    @evangeloskolimitras5276 4 года назад +1

    I get req.headers['authorization '] undefined and also with dot notation! Little weird and not finding any workaround. In the req object there is no authentication key. Any idea? Good work by the way Brad!👌

    • @vk-fb4ox
      @vk-fb4ox 3 года назад

      if you (or anyone else need to know why this happen. Look at your parameters, you may have messed up with req res order

  • @sawyerrken8112
    @sawyerrken8112 5 лет назад +3

    Awesome tutorial. Thanks for the time and effort put into this. I would rather rename that verifyToken middleware to something else like getToken to better capture what the middleware does.

    • @benargee
      @benargee 3 года назад

      Agree. Was about to comment this.

  • @yadavlokesh
    @yadavlokesh 5 лет назад

    Ton of thanks Brad for putting up this tutorial. it's really easy to follow and understand the every bit of code. Thank you again.
    Just a quick question, did you put up any tutorial for Login / registration user flow? If yes, please share link to the same.

  • @kaiferrall4096
    @kaiferrall4096 6 лет назад +1

    How do you set the auth header in your login route, so that it doesnt require you to set it in postman manually. Thanks!

  • @JohnMcCullough97
    @JohnMcCullough97 7 лет назад

    Great video. Succinct and informative. Thanks. Merry Christmas.

  • @xshad3x348
    @xshad3x348 7 лет назад

    Hi Brad, cool video and thanks, i needed a refresh! i think only that should be better to handle the verify in the middleware to keep the api clean, but great! thanks.

  • @ZaidKhanPathan
    @ZaidKhanPathan 5 лет назад +1

    Those who wants to know, what next() function is? i.e. In verifyToken(req, res, next).
    verifyToken is a middleware function in express, which take req, res and next parameters.
    Calling next will move to succeeding middleware function.
    More details here: expressjs.com/en/guide/writing-middleware.html

  • @wonjaehwang7670
    @wonjaehwang7670 5 лет назад

    At 7:14 he says we could use jwt.sign() synch or asynch. But why would you want to choose either? Could someone explain a sample use case? Like why would we want to make it asynch and run the callback after the file runs it’s execution stack? Rather than running it synchronously ?