System.Security.Cryptography.ProtectedData 9.0.1

About

System.Security.Cryptography.ProtectedData offers a simplified interface for utilizing Microsoft Windows DPAPI's CryptProtectData and CryptUnprotectData functions.

Note: Since it relies on Windows DPAPI, this package is only supported on Windows platforms. For more complex cryptographic operations or cross-platform support, consider the System.Security.Cryptography namespace.

Key Features

  • Built upon the robust and secure Windows Data Protection API (DPAPI).
  • Data can be protected either for current process or for any process on the machine.
  • Scope of protection can be defined either to the current user or the local machine.

How to Use

Utilizing this package is quite simple, and it mainly revolves around two methods: Protect and Unprotect.

Here, originalData is the data you want to protect, optionalEntropy is an additional byte array used to increase encryption complexity, and DataProtectionScope specifies whether the data protection should apply to the current user or the machine.

using System.Security.Cryptography;
using System.Text;

byte[] originalData = Encoding.UTF8.GetBytes("This is a secret");
byte[] optionalEntropy = new byte[64];
Random.Shared.NextBytes(optionalEntropy);

// To protect:
byte[] encryptedData = ProtectedData.Protect(
    originalData,
    optionalEntropy,
    DataProtectionScope.CurrentUser);

// To unprotect:
byte[] decryptedData = ProtectedData.Unprotect(
    encryptedData,
    optionalEntropy,
    DataProtectionScope.CurrentUser);

Main Types

The main type provided by this library is:

  • System.Security.Cryptography.ProtectedData

Additional Documentation

Feedback & Contributing

System.Security.Cryptography.ProtectedData is released as open source under the MIT license. Bug reports and contributions are welcome at the GitHub repository.

Showing the top 20 packages that depend on System.Security.Cryptography.ProtectedData.

Packages Downloads
Microsoft.CodeAnalysis.Workspaces.MSBuild
.NET Compiler Platform ("Roslyn") support for analyzing MSBuild projects and solutions. This should be used with at least one of the following packages to add the appropriate language support: - Microsoft.CodeAnalysis.CSharp.Workspaces - Microsoft.CodeAnalysis.VisualBasic.Workspaces More details at https://aka.ms/roslyn-packages This package was built from the source at https://github.com/dotnet/roslyn/commit/dfa7fc6bdea31a858a402168384192b633c811fa.
1
Microsoft.CodeAnalysis.VisualBasic.Features
.NET Compiler Platform ("Roslyn") support for creating Visual Basic editing experiences. More details at https://aka.ms/roslyn-packages This package was built from the source at https://github.com/dotnet/roslyn/commit/f99bb16a395e48a05520ba7af1549b20bfdeee36.
1
System.Configuration.ConfigurationManager
Provides types that support using XML configuration files (app.config). This package exists only to support migrating existing .NET Framework code that already uses System.Configuration. When writing new code, use another configuration system instead, such as Microsoft.Extensions.Configuration.
1
Microsoft.VisualStudio.Web.CodeGeneration.Core
Contains the core infrastructure used by ASP.NET Core Code Generators.
0

.NET Framework 4.6.2

  • No dependencies.

.NET 8.0

  • No dependencies.

.NET 9.0

  • No dependencies.

.NET Standard 2.0

Version Downloads Last updated
9.0.1 1 01/18/2025
9.0.0 0 11/12/2024
9.0.0-rc.2.24473.5 0 10/08/2024
9.0.0-rc.1.24431.7 0 09/10/2024
9.0.0-preview.7.24405.7 0 08/13/2024
9.0.0-preview.6.24327.7 0 07/09/2024
9.0.0-preview.5.24306.7 0 06/11/2024
9.0.0-preview.4.24266.19 0 05/21/2024
9.0.0-preview.3.24172.9 0 04/11/2024
9.0.0-preview.2.24128.5 0 03/12/2024
9.0.0-preview.1.24080.9 0 02/13/2024
8.0.0 0 11/14/2023
8.0.0-rc.2.23479.6 0 10/10/2023
8.0.0-rc.1.23419.4 0 09/12/2023
8.0.0-preview.7.23375.6 0 08/08/2023
8.0.0-preview.6.23329.7 0 07/11/2023
8.0.0-preview.5.23280.8 0 06/13/2023
8.0.0-preview.4.23259.5 0 05/16/2023
8.0.0-preview.3.23174.8 0 04/11/2023
8.0.0-preview.2.23128.3 0 03/14/2023
8.0.0-preview.1.23110.8 0 02/21/2023
7.0.1 0 02/14/2023
7.0.0 0 11/07/2022
7.0.0-rc.2.22472.3 0 10/11/2022
7.0.0-rc.1.22426.10 0 09/14/2022
7.0.0-preview.7.22375.6 0 08/09/2022
7.0.0-preview.6.22324.4 0 07/12/2022
7.0.0-preview.5.22301.12 0 06/14/2022
7.0.0-preview.4.22229.4 0 05/10/2022
7.0.0-preview.3.22175.4 0 04/13/2022
7.0.0-preview.2.22152.2 0 03/14/2022
7.0.0-preview.1.22076.8 0 02/17/2022
6.0.0 0 11/08/2021
6.0.0-rc.2.21480.5 0 10/12/2021
6.0.0-rc.1.21451.13 0 09/14/2021
6.0.0-preview.7.21377.19 0 08/10/2021
6.0.0-preview.6.21352.12 0 07/14/2021
6.0.0-preview.5.21301.5 0 06/15/2021
6.0.0-preview.4.21253.7 0 05/24/2021
6.0.0-preview.3.21201.4 0 04/08/2021
6.0.0-preview.2.21154.6 0 03/11/2021
6.0.0-preview.1.21102.12 0 02/12/2021
5.0.0 0 11/09/2020
5.0.0-rc.2.20475.5 0 10/13/2020
5.0.0-rc.1.20451.14 0 09/14/2020
5.0.0-preview.8.20407.11 0 08/25/2020
5.0.0-preview.7.20364.11 0 07/21/2020
5.0.0-preview.6.20305.6 0 06/25/2020
5.0.0-preview.5.20278.1 0 06/10/2020
5.0.0-preview.4.20251.6 0 05/18/2020
5.0.0-preview.3.20214.6 0 04/23/2020
5.0.0-preview.2.20160.6 0 04/02/2020
5.0.0-preview.1.20120.5 0 03/16/2020
4.7.0 0 12/03/2019
4.7.0-preview3.19551.4 0 11/13/2019
4.7.0-preview2.19523.17 0 11/01/2019
4.7.0-preview1.19504.10 0 10/15/2019
4.6.0 0 09/23/2019
4.6.0-rc1.19456.4 0 09/16/2019
4.6.0-preview9.19421.4 0 09/04/2019
4.6.0-preview9.19416.11 0 09/04/2019
4.6.0-preview8.19405.3 0 08/13/2019
4.6.0-preview7.19362.9 0 07/23/2019
4.6.0-preview6.19303.8 0 06/12/2019
4.6.0-preview6.19264.9 0 09/04/2019
4.6.0-preview5.19224.8 0 05/06/2019
4.6.0-preview4.19212.13 0 04/18/2019
4.6.0-preview3.19128.7 0 03/06/2019
4.6.0-preview.19073.11 0 01/29/2019
4.6.0-preview.18571.3 0 12/03/2018
4.5.0 0 05/29/2018
4.5.0-rc1 0 05/06/2018
4.5.0-preview2-26406-04 0 04/10/2018
4.5.0-preview1-26216-02 0 02/26/2018
4.5.0-preview1-25914-04 0 11/15/2017
4.4.0 0 08/11/2017
4.4.0-preview2-25405-01 0 06/27/2017
4.4.0-preview1-25305-02 0 05/09/2017
4.3.0 0 11/15/2016
4.3.0-preview1-24530-04 0 10/24/2016
4.0.0 0 06/27/2016