AspNetCore.Docs/aspnetcore/security/enforcing-ssl.md

39 lines
1.7 KiB
Markdown
Raw Normal View History

2016-10-29 01:35:15 +08:00
---
2017-07-01 07:47:15 +08:00
title: Enforcing SSL in an ASP.NET Core app
2016-10-29 01:35:15 +08:00
author: rick-anderson
description: Shows how to require SSL in a ASP.NET Core web app
keywords: ASP.NET Core,SSL,HTTPS,RequireHttpsAttribute,IIS Express
2016-10-29 01:35:15 +08:00
ms.author: riande
manager: wpickett
ms.date: 07/19/2017
2016-10-29 01:35:15 +08:00
ms.topic: article
2016-11-17 08:24:57 +08:00
ms.technology: aspnet
ms.prod: asp.net-core
2016-10-29 01:35:15 +08:00
uid: security/enforcing-ssl
---
# Enforcing SSL in an ASP.NET Core app
2016-10-29 01:35:15 +08:00
2017-07-19 06:01:43 +08:00
By [Rick Anderson](https://twitter.com/RickAndMSFT)
This document shows how to:
- Require SSL for all requests (HTTPS requests only).
- Redirect all HTTP requests to HTTPS.
## Require SSL
The [RequireHttpsAttribute](https://docs.microsoft.com/aspnet/core/api/microsoft.aspnetcore.mvc.requirehttpsattribute) is used to require SSL. You can decorate controllers or methods with this attribute or you can apply it globally as shown below:
Add the following code to `ConfigureServices` in `Startup`:
[!code-csharp[Main](authentication/accconfirm/sample/WebApp1/Startup.cs?name=snippet2&highlight=4-)]
The highlighted code above requires all requests use `HTTPS`, therefore HTTP requests are ignored. The following highlighted code redirects all HTTP requests to HTTPS:
[!code-csharp[Main](authentication/accconfirm/sample/WebApp1/Startup.cs?name=snippet_AddRedirectToHttps&highlight=7-)]
See [URL Rewriting Middleware](xref:fundamentals/url-rewriting) for more information.
Requiring HTTPS globally (`options.Filters.Add(new RequireHttpsAttribute());`) is a security best practice. Applying the
`[RequireHttps]` attribute to all controller is not considered as secure as requiring HTTPS globally. You can't guarantee new controllers added to your app will remember to apply the `[RequireHttps]` attribute.