「ASP.NET CoreのセッションをRedisに保存する」の版間の差分
ナビゲーションに移動
検索に移動
Administrator (トーク | 投稿記録) |
Administrator (トーク | 投稿記録) |
||
41行目: | 41行目: | ||
<source lang="csharp"> | <source lang="csharp"> | ||
// セッションの設定 | // セッションの設定 | ||
− | builder.Services | + | builder.Services.AddSession(options => |
{ | { | ||
options.IdleTimeout = TimeSpan.FromMinutes(60); // セッションのタイムアウト時間 | options.IdleTimeout = TimeSpan.FromMinutes(60); // セッションのタイムアウト時間 |
2024年3月7日 (木) 04:01時点における版
ASP .NET CoreのセッションをRedisに保存したい。
実装
前提
- ASP.NET Core 8.0.1
nuget
- Microsoft.Extensions.Caching.StackExchangeRedis
appsettings.json
ConnectionStringsにredisの設定を書く。
{
"ConnectionStrings": {
"redis": "localhost:6379"
},
"Logging": {
"LogLevel": {
"Default": "Information",
"Microsoft.AspNetCore": "Warning"
}
},
"AllowedHosts": "*"
}
service
appsettings.jsonを読み込みredisサービスを追加する。
// Redisの設定
builder.Services.AddStackExchangeRedisCache(options =>
{
options.Configuration = builder.Configuration.GetConnectionString("redis");
options.InstanceName = "";
});
セッションの設定をする。
// セッションの設定
builder.Services.AddSession(options =>
{
options.IdleTimeout = TimeSpan.FromMinutes(60); // セッションのタイムアウト時間
options.Cookie.Name = "session"; // セッション用のクッキー名
options.Cookie.IsEssential = true;
});
セッションを有効化する。
app.UseSession();
セッションの暗号化
asp.net coreではセッションデータが暗号化されます。 その関係で初期状態のままでは複数のサーバー(異なるアプリ)でデータ共有することができません。
暗号化の設定は2パターンあります。
- アプリ名を統一する
- 共通のキーを使う
なお、無効化はできないっぽいです。
複数のウェブサーバーのセッションを共有するだけならアプリ名の統一が簡単です。
using Microsoft.AspNetCore.DataProtection;
// 中略
builder.Services.AddDataProtection().SetApplicationName("appName");
おわり。