ASP.NET Core Data Protection は、非対称暗号化機能を提供するだけでなく、柔軟なキー保存方法と一貫した暗号化および復号化インターフェイス (保護と保護解除) も提供します。これは、セッション、Cookie 検証、OpenIdConnect で使用されます。 。 。もちろん、アプリケーション開発でも使用できます。たとえば、このブログ投稿では、アカウントをアクティブ化するための検証トークンを生成するために使用されています。
まず Startup.ConfigureServices() で DataProtection サービスを登録します (IDataProtectionProvider インターフェイスの実装を挿入します):
public void ConfigureServices(IServiceCollection services) { services.AddDataProtection(); }
次に、DataProtection を使用してクラスのコンストラクターに IDataProtectionProvider インターフェイスを追加し、このインターフェイスを使用してDataProtector を作成し、これで SecureDataFormat を作成し、最後に SecureDataFormat.Protect() メソッドを使用してトークンを生成し、アカウントをアクティブ化し、SecureDataFormat.Uprotect() を使用してトークンを復号します。完全なサンプル コードは次のとおりです。 :
public class HomeController : Controller { private readonly ISecureDataFormat<string> _dataFormat; public HomeController(IDataProtectionProvider _dataProtectionProvider) { var dataProtector = _dataProtectionProvider.CreateProtector(typeof(HomeController).FullName); _dataFormat = new SecureDataFormat<string>(new StringSerializer(), dataProtector); } public string GenerateToken() { return _dataFormat.Protect(Guid.NewGuid().ToString() + ";" + DateTime.Now.AddHours(10)); } public string DecryptToken(string token) { return _dataFormat.Unprotect(token); } private class StringSerializer : IDataSerializer<string> { public string Deserialize(byte[] data) { return Encoding.UTF8.GetString(data); } public byte[] Serialize(string model) { return Encoding.UTF8.GetBytes(model); } } }
以上がこの記事の全内容です。皆さんの学習がお役に立てば幸いです。皆さんも PHP 中国語 Web サイトをサポートしていただければ幸いです。
ASP.NET Core のデータ保護と検証トークンの生成に関連するその他の記事については、PHP 中国語 Web サイトに注目してください。