System.Security.Cryptography.ProtectedData 9.0.10

Prefix Reserved
There is a newer prerelease version of this package available.
See the version list below for details.
dotnet add package System.Security.Cryptography.ProtectedData --version 9.0.10
                    
NuGet\Install-Package System.Security.Cryptography.ProtectedData -Version 9.0.10
                    
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="System.Security.Cryptography.ProtectedData" Version="9.0.10" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="System.Security.Cryptography.ProtectedData" Version="9.0.10" />
                    
Directory.Packages.props
<PackageReference Include="System.Security.Cryptography.ProtectedData" />
                    
Project file
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add System.Security.Cryptography.ProtectedData --version 9.0.10
                    
#r "nuget: System.Security.Cryptography.ProtectedData, 9.0.10"
                    
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
#:package System.Security.Cryptography.ProtectedData@9.0.10
                    
#:package directive can be used in C# file-based apps starting in .NET 10 preview 4. Copy this into a .cs file before any lines of code to reference the package.
#addin nuget:?package=System.Security.Cryptography.ProtectedData&version=9.0.10
                    
Install as a Cake Addin
#tool nuget:?package=System.Security.Cryptography.ProtectedData&version=9.0.10
                    
Install as a Cake Tool

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.

Product Compatible and additional computed target framework versions.
.NET net5.0 was computed.  net5.0-windows was computed.  net6.0 was computed.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 was computed.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 is compatible.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed.  net9.0 is compatible.  net9.0-android was computed.  net9.0-browser was computed.  net9.0-ios was computed.  net9.0-maccatalyst was computed.  net9.0-macos was computed.  net9.0-tvos was computed.  net9.0-windows was computed.  net10.0 was computed.  net10.0-android was computed.  net10.0-browser was computed.  net10.0-ios was computed.  net10.0-maccatalyst was computed.  net10.0-macos was computed.  net10.0-tvos was computed.  net10.0-windows was computed. 
.NET Core netcoreapp2.0 was computed.  netcoreapp2.1 was computed.  netcoreapp2.2 was computed.  netcoreapp3.0 was computed.  netcoreapp3.1 was computed. 
.NET Standard netstandard2.0 is compatible.  netstandard2.1 was computed. 
.NET Framework net461 was computed.  net462 is compatible.  net463 was computed.  net47 was computed.  net471 was computed.  net472 was computed.  net48 was computed.  net481 was computed. 
MonoAndroid monoandroid was computed.  monoandroid10 is compatible. 
MonoMac monomac was computed. 
MonoTouch monotouch was computed.  monotouch10 is compatible. 
Tizen tizen40 was computed.  tizen60 was computed. 
Xamarin.iOS xamarinios was computed.  xamarinios10 is compatible. 
Xamarin.Mac xamarinmac was computed.  xamarinmac20 is compatible. 
Xamarin.TVOS xamarintvos was computed.  xamarintvos10 is compatible. 
Xamarin.WatchOS xamarinwatchos was computed.  xamarinwatchos10 is compatible. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
  • .NETFramework 4.6.2

    • No dependencies.
  • .NETStandard 2.0

  • net8.0

    • No dependencies.
  • net9.0

    • No dependencies.

NuGet packages (282)

Showing the top 5 NuGet packages that depend on System.Security.Cryptography.ProtectedData:

Package Downloads
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.

Microsoft.Identity.Client.Extensions.Msal

This package contains the public client (desktop) caching to Microsoft Authentication Library for .NET (MSAL.NET)

Microsoft.VisualStudio.Web.CodeGenerators.Mvc

Code Generators for ASP.NET Core MVC. Contains code generators for MVC Controllers and Views.

Microsoft.VisualStudio.Web.CodeGeneration.Design

Code Generation tool for ASP.NET Core. Contains the dotnet-aspnet-codegenerator command used for generating controllers and views.

Microsoft.VisualStudio.Web.CodeGeneration

Contains the CodeGenCommand that finds the appropriate code generator and invokes it from project dependencies.

GitHub repositories (70)

Showing the top 20 popular GitHub repositories that depend on System.Security.Cryptography.ProtectedData:

Repository Stars
BeyondDimension/SteamTools
🛠「Watt Toolkit」是一个开源跨平台的多功能 Steam 工具箱。
dotnet/roslyn
The Roslyn .NET compiler provides C# and Visual Basic languages with rich code analysis APIs.
rocksdanister/lively
Free and open-source software that allows users to set animated desktop wallpapers and screensavers powered by WinUI 3.
Jackett/Jackett
API Support for your favorite torrent trackers
JustArchiNET/ArchiSteamFarm
C# application with primary purpose of farming Steam cards from multiple accounts simultaneously.
mRemoteNG/mRemoteNG
mRemoteNG is the next generation of mRemote, open source, tabbed, multi-protocol, remote connections manager.
PixiEditor/PixiEditor
PixiEditor is a Universal Editor for all your 2D needs
Azure/azure-sdk-for-net
This repository is for active development of the Azure SDK for .NET. For consumers of the SDK we recommend visiting our public developer docs at https://learn.microsoft.com/dotnet/azure/ or our versioned developer docs at https://azure.github.io/azure-sdk-for-net.
actions/runner
The Runner for GitHub Actions :rocket:
PhilippC/keepass2android
Password manager app for Android
win-acme/win-acme
A simple ACME client for Windows (for use with Let's Encrypt et al.)
microsoft/perfview
PerfView is a CPU and memory performance-analysis tool
GlitchEnzo/NuGetForUnity
A NuGet Package Manager for Unity
ravendb/ravendb
ACID Document Database
cyanfish/naps2
Scan documents to PDF and more, as simply as possible.
dotnet/sdk
Core functionality needed to create .NET Core projects, that is shared between Visual Studio and CLI
googleprojectzero/sandbox-attacksurface-analysis-tools
Set of tools to analyze Windows sandboxes for exposed attack surface.
ProtonVPN/win-app
Official ProtonVPN Windows app
microsoft/PowerApps-Samples
Sample code for Power Apps, including Dataverse, model-driven apps, canvas apps, Power Apps component framework, portals, and AI Builder.
dotnet/wcf
This repo contains the client-oriented WCF libraries that enable applications built on .NET Core to communicate with WCF services.
Version Downloads Last Updated
10.0.0-rc.2.25502.107 9,915 10/14/2025
10.0.0-rc.1.25451.107 42,866 9/9/2025
10.0.0-preview.7.25380.108 12,508 8/12/2025
10.0.0-preview.6.25358.103 10,468 7/15/2025
10.0.0-preview.5.25277.114 15,313 6/6/2025
10.0.0-preview.4.25258.110 12,522 5/12/2025
10.0.0-preview.3.25171.5 18,224 4/10/2025
10.0.0-preview.2.25163.2 15,980 3/18/2025
10.0.0-preview.1.25080.5 11,556 2/25/2025
9.0.10 310,934 10/14/2025
9.0.9 1,674,590 9/9/2025
9.0.8 2,378,339 8/4/2025
9.0.7 1,720,300 7/8/2025
9.0.6 2,420,199 6/10/2025
9.0.5 2,462,864 5/13/2025
9.0.4 10,811,644 4/8/2025
9.0.3 3,125,028 3/11/2025
9.0.2 4,035,897 2/11/2025
9.0.1 4,093,359 1/14/2025
9.0.0 17,515,402 11/12/2024
9.0.0-rc.2.24473.5 151,185 10/8/2024
9.0.0-rc.1.24431.7 46,431 9/10/2024
9.0.0-preview.7.24405.7 37,730 8/13/2024
9.0.0-preview.6.24327.7 44,099 7/9/2024
9.0.0-preview.5.24306.7 23,289 6/11/2024
9.0.0-preview.4.24266.19 20,468 5/21/2024
9.0.0-preview.3.24172.9 35,395 4/11/2024
9.0.0-preview.2.24128.5 37,728 3/12/2024
9.0.0-preview.1.24080.9 65,441 2/13/2024
8.0.0 215,177,756 11/14/2023
8.0.0-rc.2.23479.6 247,976 10/10/2023
8.0.0-rc.1.23419.4 151,317 9/12/2023
8.0.0-preview.7.23375.6 71,529 8/8/2023
8.0.0-preview.6.23329.7 41,971 7/11/2023
8.0.0-preview.5.23280.8 42,236 6/13/2023
8.0.0-preview.4.23259.5 90,480 5/16/2023
8.0.0-preview.3.23174.8 80,246 4/11/2023
8.0.0-preview.2.23128.3 46,116 3/14/2023
8.0.0-preview.1.23110.8 63,624 2/21/2023
7.0.1 9,647,722 2/14/2023
7.0.0 85,278,438 11/7/2022
7.0.0-rc.2.22472.3 184,282 10/11/2022
7.0.0-rc.1.22426.10 147,915 9/14/2022
7.0.0-preview.7.22375.6 37,182 8/9/2022
7.0.0-preview.6.22324.4 43,088 7/12/2022
7.0.0-preview.5.22301.12 47,996 6/14/2022
7.0.0-preview.4.22229.4 32,847 5/10/2022
7.0.0-preview.3.22175.4 13,367 4/13/2022
7.0.0-preview.2.22152.2 28,519 3/14/2022
7.0.0-preview.1.22076.8 25,583 2/17/2022
6.0.0 534,986,193 11/8/2021
6.0.0-rc.2.21480.5 57,945 10/12/2021
6.0.0-rc.1.21451.13 78,068 9/14/2021
6.0.0-preview.7.21377.19 72,853 8/10/2021
6.0.0-preview.6.21352.12 60,592 7/14/2021
6.0.0-preview.5.21301.5 44,283 6/15/2021
6.0.0-preview.4.21253.7 69,355 5/24/2021
6.0.0-preview.3.21201.4 233,129 4/8/2021
6.0.0-preview.2.21154.6 68,882 3/11/2021
6.0.0-preview.1.21102.12 120,178 2/12/2021
5.0.0 351,220,092 11/9/2020 5.0.0 is deprecated because it is no longer maintained.
5.0.0-rc.2.20475.5 105,199 10/13/2020
5.0.0-rc.1.20451.14 58,147 9/14/2020
5.0.0-preview.8.20407.11 168,897 8/25/2020
5.0.0-preview.7.20364.11 117,250 7/21/2020
5.0.0-preview.6.20305.6 302,518 6/25/2020
5.0.0-preview.5.20278.1 23,111 6/10/2020
5.0.0-preview.4.20251.6 98,561 5/18/2020
5.0.0-preview.3.20214.6 76,011 4/23/2020
5.0.0-preview.2.20160.6 84,772 4/2/2020
5.0.0-preview.1.20120.5 61,972 3/16/2020
4.7.0 896,040,851 12/3/2019
4.7.0-preview3.19551.4 72,600 11/13/2019
4.7.0-preview2.19523.17 25,382 11/1/2019
4.7.0-preview1.19504.10 27,202 10/15/2019
4.6.0 58,279,064 9/23/2019
4.6.0-rc1.19456.4 68,474 9/16/2019
4.6.0-preview9.19421.4 26,084 9/4/2019
4.6.0-preview9.19416.11 1,343 9/4/2019
4.6.0-preview8.19405.3 103,360 8/13/2019
4.6.0-preview7.19362.9 326,963 7/23/2019
4.6.0-preview6.19303.8 1,794,812 6/12/2019
4.6.0-preview6.19264.9 1,424 9/4/2019
4.6.0-preview5.19224.8 62,067 5/6/2019
4.6.0-preview4.19212.13 15,556 4/18/2019
4.6.0-preview3.19128.7 73,269 3/6/2019
4.6.0-preview.19073.11 61,022 1/29/2019
4.6.0-preview.18571.3 128,463 12/3/2018
4.5.0 806,520,952 5/29/2018
4.5.0-rc1 149,184 5/6/2018
4.5.0-preview2-26406-04 527,175 4/10/2018
4.5.0-preview1-26216-02 504,069 2/26/2018
4.5.0-preview1-25914-04 709,496 11/15/2017
4.4.0 575,593,121 8/11/2017
4.4.0-preview2-25405-01 194,057 6/27/2017
4.4.0-preview1-25305-02 15,423 5/9/2017
4.3.0 20,839,653 11/15/2016
4.3.0-preview1-24530-04 31,044 10/24/2016
4.0.0 3,368,681 6/27/2016