AspNetCore.Docs/aspnetcore/security/authentication/social/index.md

139 lines
7.0 KiB
Markdown
Raw Normal View History

---
2016-11-17 10:52:58 +08:00
title: Enabling authentication using Facebook, Google and other external | Microsoft Docs
2016-10-29 01:35:15 +08:00
author: rick-anderson
description:
2016-12-08 04:32:53 +08:00
keywords: ASP.NET Core, authentication, social, authentication providers, google, facebook, twitter, microsoft account
2016-10-29 01:35:15 +08:00
ms.author: riande
manager: wpickett
2016-11-01 13:38:33 +08:00
ms.date: 11/1/2016
2016-10-29 01:35:15 +08:00
ms.topic: article
ms.assetid: eda7ee17-f38c-462e-8d1d-63f459901cf3
2016-11-17 10:52:58 +08:00
ms.technology: aspnet
2016-10-29 01:35:15 +08:00
ms.prod: aspnet-core
2016-12-08 04:32:53 +08:00
uid: security/authentication/social/index
2016-10-29 01:35:15 +08:00
---
2016-12-08 04:32:53 +08:00
2016-10-29 01:35:15 +08:00
# Enabling authentication using Facebook, Google and other external providers
<a name=security-authentication-social-logins></a>
2016-12-05 13:09:57 +08:00
By [Rick Anderson](https://twitter.com/RickAndMSFT), [Pranav Rastogi](https://github.com/rustd), and [Valeriy Novytskyy](https://github.com/01binary)
2016-10-29 01:35:15 +08:00
2016-11-18 13:22:41 +08:00
This tutorial demonstrates how to build an ASP.NET Core app that enables users to log in using OAuth 2.0/1.0a with credentials from external authentication providers.
2016-10-29 01:35:15 +08:00
2016-11-18 13:22:41 +08:00
[Facebook](facebook-logins.md), [Twitter](twitter-logins.md), [Google](google-logins.md), and [Microsoft](microsoft-logins.md) providers are covered in the following sections. Many third-party packages facilitate the use of other providers not covered here.
2016-11-01 13:38:33 +08:00
![Social media icons for Facebook, Twitter, Google plus, and Windows](index/_static/social.png)
2016-11-01 13:38:33 +08:00
2016-11-18 13:37:42 +08:00
Enabling users to sign in with their existing credentials is convenient for the users and shifts many of the complexities of managing the sign-in process onto a third party. For examples of how social logins can drive traffic and customer conversions, see case studies by [Facebook](https://developers.facebook.com/case-studies) and [Twitter](https://dev.twitter.com/resources/case-studies).
2016-11-01 13:38:33 +08:00
> [!NOTE]
2016-11-18 13:40:04 +08:00
> Packages presented here abstract a great deal of complexity of the OAuth authentication flow, but understanding the details may become necessary when troubleshooting. Many resources are available; for example, see [Introduction to OAuth 2](https://www.digitalocean.com/community/tutorials/an-introduction-to-oauth-2) or [Understanding OAuth 2](http://www.bubblecode.net/en/2016/01/22/understanding-oauth2/). Some issues can be resolved by looking at the [ASP.NET Core source code for the provider packages](https://github.com/aspnet/Security/tree/dev/src).
2016-10-29 01:35:15 +08:00
## Create a New ASP.NET Core Project
> [!NOTE]
2016-11-18 13:47:51 +08:00
> This tutorial requires the latest update (**Update 3**) for Visual Studio 2015 and ASP.NET Core.
2016-10-29 01:35:15 +08:00
2016-11-18 13:49:23 +08:00
* In Visual Studio, create a new project (from the Start Page, or via **File > New > Project**):
2016-10-29 01:35:15 +08:00
![New Project dialog](index/_static/new-project.png)
2016-10-29 01:35:15 +08:00
* Tap **Web Application** and verify **Authentication** is set to **Individual User Accounts**:
2016-10-29 01:35:15 +08:00
![New Web Application dialog](index/_static/select-project.png)
2016-10-29 01:35:15 +08:00
2016-11-01 13:38:33 +08:00
## Enable SSL
2016-10-29 01:35:15 +08:00
2017-01-12 04:12:41 +08:00
Some external authentication providers reject requests coming from origins that don't use the **https** protocol. This reflects the trend of major providers like [Google](https://security.googleblog.com/2014/08/https-as-ranking-signal_6.html) moving their public API services to https and discontinuing the use of unencrypted endpoints. We encourage you to follow this trend and enable SSL for your entire site. For Visual Studio 2017 RC1, see instructions below.
2016-10-29 01:35:15 +08:00
* In **Solution Explorer**, right-click the project and select **Properties**.
2016-10-29 01:35:15 +08:00
* On the left pane, tap **Debug**.
2016-10-29 01:35:15 +08:00
* Check **Enable SSL**.
2016-11-01 13:38:33 +08:00
* Copy the SSL URL and paste it into the **App URL**:
2016-10-29 01:35:15 +08:00
![Debug tab of application properties](index/_static/ssl.png)
2016-10-29 01:35:15 +08:00
2017-01-12 04:12:41 +08:00
Visual Studio 2017 RC1:
Edit the *properties/launchsettings.json* file. Add an sslPort between 44300 and 44399:
2017-01-12 06:21:10 +08:00
```
2017-01-12 04:12:41 +08:00
{
"iisSettings": {
"windowsAuthentication": false,
"anonymousAuthentication": true,
"iisExpress": {
"applicationUrl": "http://localhost:62183/",
"sslPort": 0
}
},
2017-01-12 06:21:10 +08:00
```
2017-01-12 04:12:41 +08:00
* Modify the `services.AddMvc();` code in `Startup.cs` under `ConfigureServices` to reject all requests that are not coming over *https*:
2016-10-29 01:35:15 +08:00
2016-11-18 15:35:22 +08:00
```csharp
2016-10-29 01:35:15 +08:00
services.AddMvc(options =>
{
2016-11-11 23:33:37 +08:00
options.SslPort = 44321;
2016-10-29 01:35:15 +08:00
options.Filters.Add(new RequireHttpsAttribute ());
});
2016-11-18 15:35:22 +08:00
```
2016-10-29 01:35:15 +08:00
* Test the app to ensure that static files are still being served and publicly exposed routes are accessible.
* There shouldn't be any warnings logged to the browser console in Developer Tools.
2016-11-18 13:53:52 +08:00
* Attempting to navigate to the previous URL that used the *http* protocol should now result in **connection rejected** errors from the browser or a blank page.
2016-10-29 01:35:15 +08:00
2016-11-01 13:38:33 +08:00
## Use SecretManager to store tokens assigned by login providers
2016-10-29 01:35:15 +08:00
The template used to create the sample project in this tutorial has code in `Startup.cs` which reads the configuration values from a secret store:
2016-10-29 01:35:15 +08:00
2016-12-08 04:32:53 +08:00
[!code-csharp[Main](../../../common/samples/WebApplication1/Startup.cs?highlight=11&range=20-36)]
2016-10-29 01:35:15 +08:00
2016-11-01 13:38:33 +08:00
As a best practice, it is not recommended to store the secrets in a configuration file in the application since they can be checked into source control which may be publicly accessible.
2016-10-29 01:35:15 +08:00
2016-11-18 13:22:41 +08:00
The **SecretManager** tool stores sensitive application settings in the user profile folder on the local machine. These settings are then seamlessly merged with settings from all other sources during application startup.
2016-10-29 01:35:15 +08:00
2016-12-09 01:03:17 +08:00
> [!NOTE]
2016-11-18 13:22:41 +08:00
> Most login providers assign **Application Id** and **Application Secret** during the registration process. These values are effectively the *user name* and *password* your application uses to access their API, and constitute the "secrets" linked to your application configuration with the help of **Secret Manager** instead of storing them in configuration files directly.
2016-10-29 01:35:15 +08:00
2016-12-08 04:32:53 +08:00
Install the [Secret Manager tool](../../app-secrets.md) so that you can use it to store tokens assigned by each login provider below.
2016-10-29 01:35:15 +08:00
2016-11-01 13:38:33 +08:00
## Setup login providers required by your application
2016-10-29 01:35:15 +08:00
2016-11-04 22:59:22 +08:00
Use the following pages to configure your application to use the respective providers:
2016-10-29 01:35:15 +08:00
2016-11-01 13:38:33 +08:00
* [Facebook](facebook-logins.md) instructions
* [Twitter](twitter-logins.md) instructions
* [Google](google-logins.md) instructions
* [Microsoft](microsoft-logins.md) instructions
* [Other provider](other-logins.md) instructions
2016-10-29 01:35:15 +08:00
2016-12-09 01:03:17 +08:00
> [!NOTE]
2016-11-30 08:00:57 +08:00
> Call `app.UseIdentity` (in `Configure`) before any other external providers.
## Optionally set password
When you register with an external login provider, you do not have a password registered with the app. This alleviates you from creating and remembering a password for the site, but it also makes you dependent on the external login provider. If the external login provider is unavailable, you won't be able to log in to the web site.
2016-11-18 13:37:42 +08:00
To create a password and sign in using your email that you set during the sign in process with external providers:
* Tap the **Hello <email alias>** link at the top right corner to navigate to the **Manage** view.
![Web application Manage view](index/_static/pass1a.png)
* Tap **Create**
![Set your password page](index/_static/pass2a.png)
2016-11-18 13:37:42 +08:00
* Set a valid password and you can use this to sign in with your email.
2016-10-29 01:35:15 +08:00
## Next steps
2016-11-01 13:38:33 +08:00
* This article introduced external authentication and explained the prerequisites required to add external logins to your ASP.NET Core app.
2016-10-29 01:35:15 +08:00
* Reference provider-specific pages to configure logins for the providers required by your app.