Introduction
Sign up, sign in, and Log out are three things that we always have in mind while developing a web application. The following points will be discussed in depth as part of this.
- How can I sign up or register a new user in our app?
- Built the User Login Page
- How to use the built-in Authorize Attribute
- Adding the logout functionality
- How to utilize Forms Authentication in an MVC application to accomplish all of the above goals?
The following three steps are required to implement Forms Authentication in an MVC application.
- In the web.config file, set the authentication mode to Forms.
- FormsAuthentication.SetAuthCookie is required to use for login.
- Again FormAuthentication.SignOut is required to use for logout.
Open any version of your SQL Server database and it makes no difference which version you have.
Create Employee Table
Create Department Table
Create Users Table
Create Users Table
Create UserRoles Table
Step 2
Make a new project with Visual Studio 2019 or another editor of your choice.
Step 3
Choose the "ASP.NET web application" project and give an appropriate name to your project and then click on "Create".
data:image/s3,"s3://crabby-images/6fab2/6fab257b003b10f5e04daf5d8debddcbe863678a" alt="CreateNewASPNET CreateNewASPNET"
Step 4
Then, choose “Empty” and select MVC from the checkbox and then add the project.
data:image/s3,"s3://crabby-images/a6486/a6486f971570108c4594a19f99a4243df8f72542" alt="createtheEmptyproject createtheEmptyproject"
Step 5
Add a database model by right-clicking the Models folder. Now, add the Entity Framework and for that, you have to right-click on the Models folder and then choose "New item…".
data:image/s3,"s3://crabby-images/cc289/cc289127ebe5c48dbe1253cf457b3224869163ee" alt="Modelfolder Modelfolder"
You will be presented with a window; from there, pick Data from the left panel and select ADO.NET Entity Data Model, name it EmployeeModel (this name is not required; any name will suffice), and click "Add."
data:image/s3,"s3://crabby-images/95b10/95b10a02daa3810bfbc62b30cff907d5b8dee6a7" alt="ADO.NETEntityData ADO.NETEntityData"
The wizard will open after you click "Add a window." Click "Next" after selecting EF Designer from the database.
data:image/s3,"s3://crabby-images/aa40c/aa40c4dda60f5e93687891f00851fa1c4b9a81e1" alt="EFDesigner EFDesigner"
A window will display after clicking on "Next".Select "New Connection.". After that, a new window will open. Enter your server's name, followed by a dot if it's a local server (.). Click "OK" after selecting your database.
data:image/s3,"s3://crabby-images/abed9/abed92107dc1089b0c46ccc0ec4bfe950bec946c" alt="ConnectionProperties ConnectionProperties"
The connection will be established. Save the connection name as you wish. Below is where you can modify the name of your connection. The connection will be saved in the web configuration. Now click on the "Next" button.
data:image/s3,"s3://crabby-images/4c319/4c319063629a144d4979e74b664cba3a78c08314" alt="ModelwizARD ModelwizARD"
A new window will display after you click NEXT. Click "Finish" after selecting the database table name as seen in the screenshot below.
data:image/s3,"s3://crabby-images/78de9/78de9dd435d7701935e8d9781095cbf624b95d1a" alt="CreateDatabase Createdatabase"
Now, Entity Framework is added, and a class is created for each entity in the Models folder.
data:image/s3,"s3://crabby-images/b89a0/b89a0c4a00e9be855d698d23da4868ab3cf97f2b" alt="EmployeeModel EmployeeModel"
Step 6
Now right-click the Controllers folder and then choose Add Controller.
data:image/s3,"s3://crabby-images/68aac/68aac1c02a7c8979391956a56dcdcde66f455426" alt="Controllerincontroller Controllerincontroller"
There will be a window appear. Click "Add" after selecting MVC5 Controller-Empty.
data:image/s3,"s3://crabby-images/5d05f/5d05ffea9376d39240a293676d5091fd03034018" alt="MVC5Controller-Empty MVC5Controller-Empty"
After selecting "Add," a new window with the name DefaultController will appear. Then change the name to the controller HomeController and then click on Add.
data:image/s3,"s3://crabby-images/3dfdd/3dfdd0745dadef2ca1f1723f8180df48962da413" alt="HomeController HomeController"
Step 7
When you right-click on the Index method in HomeController, the "Add View" dialogue will pop up, with the default index name selected (use a Layout page), and after that select the "Add" button to add a view for the index method.
Complete code for HomeController
Create two views, one for registration and the other for login.
Register View Code
data:image/s3,"s3://crabby-images/36b04/36b040fd707d9aeff9d4daae2555dc4304708ad0" alt="ActionMethod ActionMethod"
Register View Code
data:image/s3,"s3://crabby-images/947a9/947a955d1f4ef8e09db5a1cba1c50dfd7e0e0ad2" alt="LoginActionMethod LoginActionMethod"
Login View Code
Looking for Trusted Dot Net Development Company For Your Business?
Step 8
Add the following code to the system.web section of the web.config file for forms authentication.
Step 9Similarly, another controller for CRUD operations should be added by right-clicking on the Controllers folder and select Add Controller.
data:image/s3,"s3://crabby-images/f16db/f16db1b349b86eb7cfae9e4b5650fe15b15f22c8" alt="theMVC5controller theMVC5controller"
A new window will open. Click "Add" to add an MVC5 Controller with a view that uses Entity Framework.
data:image/s3,"s3://crabby-images/0a280/0a2806c686a47db9a7e42dc5c998bd22bae1f124" alt="usingEntityFramework usingEntityFramework"
A new window will display after clicking on "Add", Select a model class and a database context class, and then click on Add. It will create the respective views with the controller - create, edit, update, and delete code and views.
data:image/s3,"s3://crabby-images/fd584/fd584d89de8de18f3a7a371ec005cfa9122b3fe1" alt="classandDatacontext classandDatacontext"
Use Authorize Attribute
The Authorize Attribute is a built-in MVC attribute that is used to authenticate a user.Use the Authorize Attribute to protect the action methods that you don't want anonymous users to see.
Step 10
Example
Modify the _Layout.cshtml file with the following code.
Step 11.Build and run your ASP.net web application with ctrl + F5
Conclusion
In this blog, we learned forms authentication in the Asp.Net web application with an example. It will effectively help in comprehending the essentiality of authentication.
Content source: https://www.ifourtechnolab.com/blog/explain-forms-authentication-in-asp-net-mvc