AspNetCore.Docs/aspnetcore/security/authentication/2fa.md

150 lines
7.1 KiB
Markdown
Raw Normal View History

2016-10-29 01:35:15 +08:00
---
title: Two-factor authentication with SMS in ASP.NET Core
2016-10-29 01:35:15 +08:00
author: rick-anderson
description: Learn how to set up two-factor authentication (2FA) with an ASP.NET Core app.
2016-10-29 01:35:15 +08:00
manager: wpickett
2018-01-29 23:21:31 +08:00
ms.author: riande
2017-09-20 02:44:04 +08:00
ms.date: 08/15/2017
ms.prod: asp.net-core
2018-01-29 23:21:31 +08:00
ms.technology: aspnet
ms.topic: article
2016-10-29 01:35:15 +08:00
uid: security/authentication/2fa
---
# Two-factor authentication with SMS in ASP.NET Core
2016-10-29 01:35:15 +08:00
By [Rick Anderson](https://twitter.com/RickAndMSFT) and [Swiss-Devs](https://github.com/Swiss-Devs)
2016-10-29 01:35:15 +08:00
This tutorial applies to ASP.NET Core 1.x only. See [Enable QR Code generation for authenticator apps in ASP.NET Core](xref:security/authentication/identity-enable-qrcodes) for ASP.NET Core 2.0 and later.
2017-08-16 03:45:35 +08:00
This tutorial shows how to set up two-factor authentication (2FA) using SMS. Instructions are given for [twilio](https://www.twilio.com/) and [ASPSMS](https://www.aspsms.com/asp.net/identity/core/testcredits/), but you can use any other SMS provider. We recommend you complete [Account Confirmation and Password Recovery](xref:security/authentication/accconfirm) before starting this tutorial.
2016-10-29 01:35:15 +08:00
View the [completed sample](https://github.com/aspnet/Docs/tree/master/aspnetcore/security/authentication/2fa/sample/Web2FA). [How to download](xref:tutorials/index#how-to-download-a-sample).
2016-10-29 01:35:15 +08:00
## Create a new ASP.NET Core project
Create a new ASP.NET Core web app named `Web2FA` with individual user accounts. Follow the instructions in [Enforce SSL in an ASP.NET Core app](xref:security/enforcing-ssl) to set up and require SSL.
2016-10-29 01:35:15 +08:00
### Create an SMS account
2016-10-29 01:35:15 +08:00
Create an SMS account, for example, from [twilio](https://www.twilio.com/) or [ASPSMS](https://www.aspsms.com/asp.net/identity/core/testcredits/). Record the authentication credentials (for twilio: accountSid and authToken, for ASPSMS: Userkey and Password).
2016-10-29 01:35:15 +08:00
#### Figuring out SMS Provider credentials
**Twilio:**
From the Dashboard tab of your Twilio account, copy the **Account SID** and **Auth token**.
**ASPSMS:**
From your account settings, navigate to **Userkey** and copy it together with your **Password**.
We will later store these values in with the secret-manager tool within the keys `SMSAccountIdentification` and `SMSAccountPassword`.
#### Specifying SenderID / Originator
**Twilio:**
From the Numbers tab, copy your Twilio **phone number**.
**ASPSMS:**
Within the Unlock Originators Menu, unlock one or more Originators or choose an alphanumeric Originator (Not supported by all networks).
We will later store this value with the secret-manager tool within the key `SMSAccountFrom`.
### Provide credentials for the SMS service
2016-10-29 01:35:15 +08:00
We'll use the [Options pattern](xref:fundamentals/configuration/options) to access the user account and key settings.
2016-10-29 01:35:15 +08:00
* Create a class to fetch the secure SMS key. For this sample, the `SMSoptions` class is created in the *Services/SMSoptions.cs* file.
2016-10-29 01:35:15 +08:00
[!code-csharp[](2fa/sample/Web2FA/Services/SMSoptions.cs)]
2016-10-29 01:35:15 +08:00
Set the `SMSAccountIdentification`, `SMSAccountPassword` and `SMSAccountFrom` with the [secret-manager tool](xref:security/app-secrets). For example:
2016-10-29 01:35:15 +08:00
2016-11-18 13:03:07 +08:00
```none
C:/Web2FA/src/WebApp1>dotnet user-secrets set SMSAccountIdentification 12345
info: Successfully saved SMSAccountIdentification = 12345 to the secret store.
2016-11-18 13:03:07 +08:00
```
* Add the NuGet package for the SMS provider. From the Package Manager Console (PMC) run:
2016-10-29 01:35:15 +08:00
**Twilio:**
`Install-Package Twilio`
2016-10-29 01:35:15 +08:00
**ASPSMS:**
`Install-Package ASPSMS`
* Add code in the *Services/MessageServices.cs* file to enable SMS. Use either the Twilio or the ASPSMS section:
**Twilio:**
[!code-csharp[](2fa/sample/Web2FA/Services/MessageServices_twilio.cs)]
2016-10-29 01:35:15 +08:00
**ASPSMS:**
[!code-csharp[](2fa/sample/Web2FA/Services/MessageServices_ASPSMS.cs)]
2016-10-29 01:35:15 +08:00
### Configure startup to use `SMSoptions`
2016-10-29 01:35:15 +08:00
Add `SMSoptions` to the service container in the `ConfigureServices` method in the *Startup.cs*:
2016-10-29 01:35:15 +08:00
[!code-csharp[](2fa/sample/Web2FA/Startup.cs?name=snippet1&highlight=4)]
2016-10-29 01:35:15 +08:00
### Enable two-factor authentication
2016-10-29 01:35:15 +08:00
Open the *Views/Manage/Index.cshtml* Razor view file and remove the comment characters (so no markup is commnted out).
2016-10-29 01:35:15 +08:00
## Log in with two-factor authentication
* Run the app and register a new user
![Web application Register view open in Microsoft Edge](2fa/_static/login2fa1.png)
2016-10-29 01:35:15 +08:00
* Tap on your user name, which activates the `Index` action method in Manage controller. Then tap the phone number **Add** link.
![Manage view](2fa/_static/login2fa2.png)
2016-10-29 01:35:15 +08:00
* Add a phone number that will receive the verification code, and tap **Send verification code**.
![Add Phone Number page](2fa/_static/login2fa3.png)
2016-10-29 01:35:15 +08:00
* You will get a text message with the verification code. Enter it and tap **Submit**
![Verify Phone Number page](2fa/_static/login2fa4.png)
2016-10-29 01:35:15 +08:00
If you don't get a text message, see twilio log page.
2016-10-29 01:35:15 +08:00
* The Manage view shows your phone number was added successfully.
![Manage view](2fa/_static/login2fa5.png)
2016-10-29 01:35:15 +08:00
* Tap **Enable** to enable two-factor authentication.
![Manage view](2fa/_static/login2fa6.png)
2016-10-29 01:35:15 +08:00
### Test two-factor authentication
* Log off.
* Log in.
* The user account has enabled two-factor authentication, so you have to provide the second factor of authentication . In this tutorial you have enabled phone verification. The built in templates also allow you to set up email as the second factor. You can set up additional second factors for authentication such as QR codes. Tap **Submit**.
![Send Verification Code view](2fa/_static/login2fa7.png)
2016-10-29 01:35:15 +08:00
* Enter the code you get in the SMS message.
* Clicking on the **Remember this browser** check box will exempt you from needing to use 2FA to log on when using the same device and browser. Enabling 2FA and clicking on **Remember this browser** will provide you with strong 2FA protection from malicious users trying to access your account, as long as they don't have access to your device. You can do this on any private device you regularly use. By setting **Remember this browser**, you get the added security of 2FA from devices you don't regularly use, and you get the convenience on not having to go through 2FA on your own devices.
![Verify view](2fa/_static/login2fa8.png)
2016-10-29 01:35:15 +08:00
## Account lockout for protecting against brute force attacks
2018-03-10 08:38:37 +08:00
Account lockout is recommended with 2FA. Once a user signs in through a local account or social account, each failed attempt at 2FA is stored. If the maximum failed access attempts is reached, the user is locked out (default: 5 minute lockout after 5 failed access attempts). A successful authentication resets the failed access attempts count and resets the clock. The maximum failed access attempts and lockout time can be set with [MaxFailedAccessAttempts](/dotnet/api/microsoft.aspnetcore.identity.lockoutoptions.maxfailedaccessattempts) and [DefaultLockoutTimeSpan](/dotnet/api/microsoft.aspnetcore.identity.lockoutoptions.defaultlockouttimespan). The following configures account lockout for 10 minutes after 10 failed access attempts:
2016-10-29 01:35:15 +08:00
2018-03-10 08:38:37 +08:00
[!code-csharp[](2fa/sample/Web2FA/Startup.cs?name=snippet2&highlight=13-17)]
Confirm that [PasswordSignInAsync](/dotnet/api/microsoft.aspnetcore.identity.signinmanager-1.passwordsigninasync) sets `lockoutOnFailure` to `true`:
```csharp
var result = await _signInManager.PasswordSignInAsync(
Input.Email, Input.Password, Input.RememberMe, lockoutOnFailure: true);
```