C# Corner

ASP.NET Core Security, Part 1

To start my series on ASP.NET Core security, I'll show how to set up authentication to register, log in and log out a user account in an ASP.NET Core MVC application. To get started, open Visual Studio 2017 and create a new ASP.NET Core Web Application as seen in Figure 1.

Create New ASP.NET Core Web App
[Click on image for larger view.] Figure 1. Create New ASP.NET Core Web App

Next click on the Change Authentication button on the next dialog as seen in Figure 2.

Change Authentication Dialog
[Click on image for larger view.] Figure 2. Change Authentication Dialog

Then change the authentication type to "Individual User Accounts" as seen in Figure 3.

Individual User Accounts Setting
[Click on image for larger view.] Figure 3. Individual User Accounts Setting

Next click the OK button to create the new ASP.NET Core Web Application as seen in Figure 4.

Create App with Authentication Set
[Click on image for larger view.] Figure 4. Create App with Authentication Set

Next we are going to create the database for our application. Go to Tools |NuGet Package Manager | Package Manager Console as seen in Figure 5.

Open Package Manger Console
[Click on image for larger view.] Figure 5. Open Package Manger Console

Then run the "Update-Database" command in the console.

Your app is now configured to allow a user to register a user, log in an existing user and log out an existing user. To test this functionality, first register a new user by clicking on the Register link as seen in Figure 6.

Finished App
[Click on image for larger view.] Figure 6. Finished App

Once you click on the Register link you should see the User Registration page as seen in Figure 7.

Register User
[Click on image for larger view.] Figure 7. Register User

After you register a user you'll see that you're automatically logged in as seen in Figure 8.

Logged In!
[Click on image for larger view.] Figure 8. Logged In!

Now you can test out logging out a user by clicking on the Logout link in Figure 8. Lastly, test out the Login functionality by clicking on the Login link from Figure 7. You should now see the Login form as seen in Figure 9.

Login an Existing User
[Click on image for larger view.] Figure 9. Log in an Existing User

In this intro to the ASP.NET Core security series, I've shown you how easy it is to use the built-in authentication provider in ASP.NET Core. Stay tuned for the next installment where I'll show you how to put pages behind log in and create user roles, and use existing roles to restrict access to pages.

About the Author

Eric Vogel is a Senior Software Developer for Red Cedar Solutions Group in Okemos, Michigan. He is the president of the Greater Lansing User Group for .NET. Eric enjoys learning about software architecture and craftsmanship, and is always looking for ways to create more robust and testable applications. Contact him at [email protected].

comments powered by Disqus

Featured

  • Full Stack Hands-On Development with .NET

    In the fast-paced realm of modern software development, proficiency across a full stack of technologies is not just beneficial, it's essential. Microsoft has an entire stack of open source development components in its .NET platform (formerly known as .NET Core) that can be used to build an end-to-end set of applications.

  • .NET-Centric Uno Platform Debuts 'Single Project' for 9 Targets

    "We've reduced the complexity of project files and eliminated the need for explicit NuGet package references, separate project libraries, or 'shared' projects."

  • Creating Reactive Applications in .NET

    In modern applications, data is being retrieved in asynchronous, real-time streams, as traditional pull requests where the clients asks for data from the server are becoming a thing of the past.

  • AI for GitHub Collaboration? Maybe Not So Much

    No doubt GitHub Copilot has been a boon for developers, but AI might not be the best tool for collaboration, according to developers weighing in on a recent social media post from the GitHub team.

  • Visual Studio 2022 Getting VS Code 'Command Palette' Equivalent

    As any Visual Studio Code user knows, the editor's command palette is a powerful tool for getting things done quickly, without having to navigate through menus and dialogs. Now, we learn how an equivalent is coming for Microsoft's flagship Visual Studio IDE, invoked by the same familiar Ctrl+Shift+P keyboard shortcut.

Subscribe on YouTube