How to Implement Refresh Token in ASP.NET Core Web API

  Рет қаралды 13,341

Code Maze

Code Maze

Күн бұрын

Пікірлер: 47
@CodeMaze
@CodeMaze 10 ай бұрын
Thank you all for watching and for your support. ►► If you want to check out all our courses you can do that here: courses.code-maze.com/courses/
@elohimcode
@elohimcode 11 ай бұрын
You made refreshtoken implementation simpler. Thanks for sharing 😊
@CodeMaze
@CodeMaze 11 ай бұрын
Glad it was helpful! Thank you for watching.
@PowersoftIT
@PowersoftIT 5 ай бұрын
How to implement from client application like angular or MAUI
@I-PixALbI4-I
@I-PixALbI4-I 11 ай бұрын
Just yesterday implement refresh token but a bit different, using cookies for refresh token. Thx for video!
@CodeMaze
@CodeMaze 11 ай бұрын
Thank you for watching. Yeah, it can be done that way as well. For Web APIs I usually lean a bit more to JWT comparing to server-side apps like Blazor Server or Razor Pages, where I would probably go with cookies as well.
@Sharondevbd
@Sharondevbd 5 ай бұрын
Great! I Hope I Founded the right Tutorial & Channel
@CodeMaze
@CodeMaze 5 ай бұрын
I hope so too! Thank you for watching the video.
@zameer.vighio
@zameer.vighio 7 ай бұрын
Thanks first. Excellent way of explaining
@CodeMaze
@CodeMaze 7 ай бұрын
You are most welcome.
@LuckyBwaromalePaul
@LuckyBwaromalePaul 8 ай бұрын
Thanks for the video. Appreciate
@CodeMaze
@CodeMaze 8 ай бұрын
My pleasure! Thank you for watching.
@tanoryjakaperdana1419
@tanoryjakaperdana1419 8 ай бұрын
Why if token.expire
@tanoryjakaperdana1419
@tanoryjakaperdana1419 8 ай бұрын
Ah sorry my bad.. im a bit sleepy and didnt read well 😅
@CodeMaze
@CodeMaze 8 ай бұрын
So, you understand why?
@tanoryjakaperdana1419
@tanoryjakaperdana1419 8 ай бұрын
​@@CodeMazei missread it.. its if refreshtokenexpire
@CodeMaze
@CodeMaze 8 ай бұрын
Ah ok. Makes sense. I thought you were talking about refresh token from begining :)
@tanoryjakaperdana1419
@tanoryjakaperdana1419 8 ай бұрын
@@CodeMaze haha sorry.. im trying to use sigin with google button (not google auth) and then convert the credential from google to jwtauth.. thanks for the video
@salihe1232
@salihe1232 5 ай бұрын
why are we encyrpting refresh token with RandomNumberGenerator Class can't we make that JWT too
@CodeMaze
@CodeMaze 5 ай бұрын
Hi. No, I am not encrypting a refresh token. I am using that mentioned class to generate one. Refresh token isn't the same as the access token, so you don't need another JWT. You don't need claims and other stuff JWT has inside.
@salihe1232
@salihe1232 5 ай бұрын
@@CodeMaze So i want to publish a api and every api developer is doing like this way.So you say it is secure to publish it like that we don't need to encrypt the refresh token
@CodeMaze
@CodeMaze 5 ай бұрын
You can do it this way. If you have a client app that consumes your API and stores the tokens in local or session storage, you can encrypt the access token inside the client app first, and then store it in the storage. Of course, everytime you send that token with a request, you need to decript it first.
@salihe1232
@salihe1232 5 ай бұрын
@@CodeMaze Thank you !!😇
@alexalexander3252
@alexalexander3252 5 ай бұрын
Hello, great video. Thou I can not get the following. What is "principal.Identity.Name" construction in RefreshToken method? Where does this "identity" property comes from? As you did not populate this prop when creating GetClaimsPrincipalFromToken method. I have a NULL in this value.
@CodeMaze
@CodeMaze 5 ай бұрын
Hi. It is the Name claim that you assign while creating the token. Identity represents a property from the ClaimsPrincipal class and that property gets the primary claims of the current principal.
@coder3123
@coder3123 11 ай бұрын
if someone gets hold of refresh token would they not able to use it to generate as many access tokens as they want?
@CodeMaze
@CodeMaze 11 ай бұрын
Well, yes. But that's really dangerous case. Basically, look at it this way, if someone gets keys of your appartment, what you can do until you notice that. This is something we try to avoid by storing the refresh tokens safely in our client applications that uses the Web API. On the client you can encrypt it and store it so if by any chance someone gets it, it would be meaningless to them. But if someone can intercept your HTTP requests, than you have bigger issues. Also, refresh tokens are not only about security but also about better user experience so we need to look them that way as well.
@weradsaoud2018
@weradsaoud2018 8 ай бұрын
Thank you
@CodeMaze
@CodeMaze 8 ай бұрын
You're welcome. Thank you for watching.
@johannes3980
@johannes3980 8 ай бұрын
I have a question. When I have a MAUI app as the client, for example, what is the best practice for the refresh flow to maintain a high user experience? Because when the access token is invalid, it would take six calls until I have the data if the token needs to be refreshed. So, should the token be refreshed in the background if it’s expired to maintain a high UX?
@CodeMaze
@CodeMaze 8 ай бұрын
Hi. I never worked with MAUI so I am not sure what is going on there, but usually, on the client app, you should have some sort of interceptor that will intercept the request and check the token you are sending with the request and if it is about to expire or expired, you can first send the request to the Token endpoint to refresh the token, and then attach that new token to the request. That's the case with JWT auth.
@ahmedrizk106
@ahmedrizk106 5 ай бұрын
this approach does not support user logging from multiple clients since there is only one refresh token/user at a time then once the first client consume it the second client will log out the user.
@CodeMaze
@CodeMaze 5 ай бұрын
You are correct, and you shouldn't support that as well as it can be resky and so many companies abandoned that approach. Now, if you have a single user, you should be logged in from a single client.
@ahmedrizk106
@ahmedrizk106 5 ай бұрын
@@CodeMaze how can you abandon supporting multiple clients when most apps have a mobile app and a web app and the user can be logged in on both at the same time ?
@CodeMaze
@CodeMaze 5 ай бұрын
No, those are not the same. Web app and the mobile app are not using the same method. If you are using a mobile phone to access the web app, than it is the same thing and it shouldn't be supported. But mobile apps are different things.
@ahmedrizk106
@ahmedrizk106 5 ай бұрын
@@CodeMaze sorry I misspoke what I meant was a mobile app and a web app accessing the same apis or maybe you are logged in from your laptop and your pc at the same time which is a common scenario how can you solve this ?
@CodeMaze
@CodeMaze 5 ай бұрын
I am not solving that. As I said, when you have an API and a usual SPA client that consumes that API, it is a security risk to allow a single user to be logged in from multiple browsers. Because of that, for me, it is the rule that the user can use only a single browser/tab and be logged in.
@mohamedroshdy4916
@mohamedroshdy4916 11 ай бұрын
can share with us this demo😇
@CodeMaze
@CodeMaze 11 ай бұрын
Hi. We will soon provide the option for the source code.
@Famouse
@Famouse 11 ай бұрын
Can you give a link to the source code?
@CodeMaze
@CodeMaze 11 ай бұрын
Hi. We are working on it. Soon, you will be able to get the source code for all the videos.
@Famouse
@Famouse 11 ай бұрын
Well, thank you.@@CodeMaze
@shahidwani6445
@shahidwani6445 Ай бұрын
What if hacker gets both tokens
@CodeMaze
@CodeMaze Ай бұрын
There is nothing much to say there - you have a serious security issue then. This simply shouldn't happen. But if you have a client app, and you store your tokens in some sort of storage, you can encrypt them in the client app first and then store them. That way, if someone steals them, the tokens will be of no value to them. Of course, you have to remember to decrypt them before using them in the request.
@Famouse
@Famouse 11 ай бұрын
Is there a link to the source code?
@CodeMaze
@CodeMaze 11 ай бұрын
I am really sorry, but it will be soon an option for that as well. It is a bit harder as this is part of our book's source code and I have to divide it somehow to leave only the relevant parts there. It would be unfair for the people who purchased the book to share the source code of the entire project.
@Famouse
@Famouse 11 ай бұрын
Ok. No problem.@@CodeMaze
Implement API Key Authentication in ASP.NET Core Web API
19:06
Master Refresh Tokens in ASP.NET Core (building from scratch)
17:19
Milan Jovanović
Рет қаралды 13 М.
Try this prank with your friends 😂 @karina-kola
00:18
Andrey Grechka
Рет қаралды 9 МЛН
When you have a very capricious child 😂😘👍
00:16
Like Asiya
Рет қаралды 18 МЛН
REAL or FAKE? #beatbox #tiktok
01:03
BeatboxJCOP
Рет қаралды 18 МЛН
Forget Controllers and Minimal APIs in .NET!
14:07
Nick Chapsas
Рет қаралды 82 М.
Stay Fresh: .NET 7 Web API Refresh Tokens 🌊
18:25
Patrick God
Рет қаралды 21 М.
What are Refresh Tokens?! and...How to Use Them Securely
19:29
Implementing JWT Authentication in ASP.NET Core
23:51
Nick Chapsas
Рет қаралды 51 М.
Hangfire in ASP.NET Core - Handle Background Jobs Easily
15:59
Code Maze
Рет қаралды 3,7 М.
Session Vs JWT: The Differences You May Not Know!
7:00
ByteByteGo
Рет қаралды 334 М.
Try this prank with your friends 😂 @karina-kola
00:18
Andrey Grechka
Рет қаралды 9 МЛН