Authentication plays a very important role to keep an organization's data/network etc secure. There are many authentication approaches available in the market, but the most popular approach is “Token Based Authentication”.
In this article, we are going to discuss and implement Token Based Authentication with Asp.net Core Web API 5.0 + JWT (JSON Web Token).
We will create a simple Web API to understand JWT. We can use postman or swagger to test our Web API once it's done.
I recommend to read this article first if you are not aware of JWT and then come back for implementation.
What is Token-based authentication?
Before we start, we should know what Authentication is.
In simple words we can say, Authentication is validating the user with credentials or identity.
Now next question comes in the mind is “What is Token based authentication in Web API”?
Token Base Authentication processes,
- The client sent a request to the server with credentials.
- The server validates the credential and creates an Access token and sends it back to the client.
- All subsequence requests content this token until its expired.
There are many Open standards available in the market to implement Token Based Authentication in Web API and JSON WEB TOKEN(JWT) is the most popular among them.
Steps to follow to create JWT Authentication in Web API
Web API Project has the below endpoints,
- /authenticate – Authenticate Member Credential and send Access token for subsequence request.
- /All members – Return List of Members.
- / MemberByid /id - Members filter by id and return a single member.
Let us create the project using Visual Studio 2019.
Step 1
Create a new project.
Step 2
Select the “Asp.Net Core Web API” template and click on the Next button.
Step 3
Configure Project Name, location as per the above screen. Click on the Next button.
Step 4
Provide Target Framework (.Net 5.0) and click on create button to create a Web API project.
“MemberJWTDemo” Project has been created successfully, and default solution should look likethe above image.
The initial Project setup is ready, now follow the below steps to implement JWT Authentication.
Step 5
Remove default controller “WeatherForecastController.cs” and “WeatherForcast.cs” files from the project.
Step 6
We need to Enable Authentication in middleware to validate members. To do so, open the Startup.cs file and add the below code,
To validate member’s credentials and generate JWT tokens, we need a custom authentication class.
Step 7
First, we will create an interface called the”IJwtAuth.cs” file,
Step 8
Now add a new class called “Auth” and Implement the “IAuth” interface.
Step 9
We need to add Nuget package “Microsoft.AspNetCore.Authentication” for Authentication.
We will keep the username and password hardcoded for demo purposes. In the real-world scenario, it will come from a database.
If the user is authenticated successfully then we will create a JWT token.
Step 10
To create JWT Token we need to install Nuget package “System.IdentityModel.Tokens.Jwt”.
Step 11
Now we will write the below code in Auth class - Authentication method to create token after authenticating.
In the above code,
- Create Security Handler – “token handler”.
- Once Token Handler is created, we will encrypt the key into bytes.
- Now we will create a token descriptor.
- Subject – New Claim identity
- Expired – When it will be expired.
- SigningCredentical – Private key + Algorithm
- Now we will create a token using the “create token” method of the token handler.
- Return token from Authentication method.
Now we will create a controller and use this authentication method.
Step 12
Create New Controller “Members” with HTTP POST endpoint called Authentication.
Step 13
Click on Add and Provide controller name in the below screen,
In the above code,
- The authentication method took the user name and password from the body.
- Pass credential to the jwtAuth. Authentication method to get token.
- Return token.
- Add attributes [AllowAnonymous] as this method can be handled by any user.
- Add [Authorize] attributes to Member controller.
- Add “jwtAuth” in the constructor.
Step 14
Create UserCredential Class as below,
Step 15
Create Member model class as below,
We need to add dependency in the Startup.cs file. Also, we will add JETBearar to decrypt the key.
Step 16
Install “Microsoft.AspNetCore.Authentication.JwtBearer” NuGet package.
Step 17
Add the below code in the startup.cs file,
We are done with code.
Step 18
Now we will call API endpoint using Postman or swagger etc.
Step 19
First, we will call post method /API/Members/authentication,
The token is created successfully. Now in the subsequence request, we have to pass this token in header(Key - authorized, and value -token)
I hope you enjoy this article and find it useful.
No comments:
Post a Comment