AspNetCore.Docs/aspnetcore/security/data-protection/implementation/key-immutability.md

2.5 KiB

title author description manager ms.author ms.date ms.prod ms.technology ms.topic uid
Key immutability and key settings in ASP.NET Core rick-anderson Learn the implementation details of the ASP.NET Core Data Protection key immutability APIs. wpickett riande 10/14/2016 asp.net-core aspnet article security/data-protection/implementation/key-immutability

Key immutability and key settings in ASP.NET Core

Once an object is persisted to the backing store, its representation is forever fixed. New data can be added to the backing store, but existing data can never be mutated. The primary purpose of this behavior is to prevent data corruption.

One consequence of this behavior is that once a key is written to the backing store, it's immutable. Its creation, activation, and expiration dates can never be changed, though it can revoked by using IKeyManager. Additionally, its underlying algorithmic information, master keying material, and encryption at rest properties are also immutable.

If the developer changes any setting that affects key persistence, those changes won't go into effect until the next time a key is generated, either via an explicit call to IKeyManager.CreateNewKey or via the data protection system's own automatic key generation behavior. The settings that affect key persistence are as follows:

If you need these settings to kick in earlier than the next automatic key rolling time, consider making an explicit call to IKeyManager.CreateNewKey to force the creation of a new key. Remember to provide an explicit activation date ({ now + 2 days } is a good rule of thumb to allow time for the change to propagate) and expiration date in the call.

[!TIP] All applications touching the repository should specify the same settings with the IDataProtectionBuilder extension methods. Otherwise, the properties of the persisted key will be dependent on the particular application that invoked the key generation routines.