3

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();
}

ここで何が間違っていますか?

4

1 に答える 1