MVS 2012 SQL Server 2008 R2
セッション ラッパーを使用してセッションに格納されているオブジェクトがあります。ログイン時に、オブジェクトを初期化し、セッションを適切に設定します。ユーザーを認証した後、ユーザーをユーザー インデックス ページにリダイレクトします。ユーザーはインデックス ページにリダイレクトされますが、セッション変数は null ではありません。なぜそれが起こっているのかわかりません。これが私がやっていることのサンプルコードです。
これが私のWeb構成設定です。この Web 構成セクションをコメントアウトしてアプリケーションを再度実行すると、問題なく動作しました。
<sessionState mode="SQLServer" allowCustomSqlDatabase="true" timeout="60" cookieless="false" sqlConnectionString="Data Source=(****);Initial Catalog=data1;User ID=****;Password=****;Integrated Security=True" />
これは、セッションでラップされるオブジェクトです
public class CurrentRequest
{
public int UserId { get; set; }
public string Role { get; set; }
}
ここにセッションラッパーがあります
public static CurrentRequest currentRequest
{
get
{
if (HttpContext.Current.Session["request"] != null)
{
return (CurrentRequest)HttpContext.Current.Session["request"];
}
else
{
return null;
}
}
set
{
HttpContext.Current.Session["request"] = value;
}
}
ここでロールを確認し、ユーザーを適切なページにリダイレクトします
CurrentRequest currentRequest = new CurrentRequest();
SessionWrapper.currentRequest = currentRequest;
int userId = login.GetUserId(model.UserName, true);
SessionWrapper.currentRequest.UserName = model.UserName;
string[] roles = Roles.GetRolesForUser(model.UserName);
if (roles.Count() > 0)
{
string aRole = roles[0];
switch (aRole)
{
case "Admin":
SessionWrapper.currentRequest.Role = aRole;
SessionWrapper.currentRequest.UserId = userId;
.
.
上記のセッション変数は適切に設定されており、ユーザーをユーザーのインデックス ページにリダイレクトしています。
return RedirectToAction("Index", "Users");
case "User":
ユーザーコントローラーで、このユーザーが管理者かどうかを確認していますが、セッション変数 SessionWrapper.currentRequest が null です
if (SessionWrapper.currentRequest.Role == "Admin")
{
users = db.UserRepository.GetAll();
}
ここで何が間違っていますか?