2

我有这个代码

[HttpPost]
public ActionResult Index(LoginModel loginModel)
{
    if (ModelState.IsValid)
    { 
       // some lines of code . bla bla bla
       TempData["loginModel"] = loginModel;
       return RedirectToAction("index", "premium");
     }
     ...
}

这个控制器在这里

public ActionResult Index()
{
   var loginModel = TempData["loginModel"] as LoginModel;
   ...
}

现在,当页面加载时,一切似乎都正常。但是当我刷新时,一切都搞砸了,它说 loginModel 就像 null。问题是,我怎样才能跟踪当前的登录用户。我启用了表单身份验证。tnx

错误如下


Object reference not set to an instance of an object.

Description: An unhandled exception occurred during the execution of the current web     request. Please review the stack trace for more information about the error and where it originated in the code. 

Exception Details: System.NullReferenceException: Object reference not set to an instance of an object.

Source Error: 


Line 22: 
Line 23:             var loginModel = TempData["loginModel"] as LoginModel;
Line 24:             string username = loginModel.username;
Line 25:             string password = loginModel.password;
Line 26:             premiumModel.username = username;
4

4 回答 4

6

混乱

但是当我刷新时,一切都搞砸了,它说 loginModel 就像 null

回答

这是因为您已读取TempData密钥,并且一旦读取,该特定密钥的数据将丢失。

var Value = TempData["keyName"] //Once read, data will be lost

问题

我怎样才能跟踪当前的登录用户

回答

因此,即使在读取数据后也要保留数据,您可以像下面这样活着

var Value = TempData["keyName"];
TempData.Keep();                 //Data will not be lost for all Keys
TempData.Keep("keyName");        //Data will not be lost for this Key

TempData也可以在新选项卡/窗口中使用,就像Session变量一样。

您也可以使用Session变量,唯一的主要问题是Session变量与TempData. 最后,您还可以跨控制器/区域保留数据。

希望这篇文章对你有很大帮助。

于 2013-06-19T19:28:55.437 回答
2

一旦用户通过身份验证,您只需存储用户的身份(用户名) - 不需要密码。因此,ASP.NET 身份验证已经支持将用户身份存储在身份验证 cookie 中,您不必重新发明轮子。您可以使用Controller.User属性获取身份。

编辑:我假设您已经为表单身份验证正确设置了您的应用程序。无论如何,这里有一些入门指南/教程链接:

  1. http://www.apexa.net/Blog/web_design_Blog_20100319.aspx
  2. http://www.asp.net/mvc/tutorials/authenticating-users-with-forms-authentication-cs
  3. 解释解决方案,这样您就不必在每个操作上应用 Authorize 属性 - http://blogs.msdn.com/b/rickandy/archive/2011/05/02/securing-your-asp-net-mvc-3 -application.aspx
于 2011-09-29T05:33:31.413 回答
1

TempData只为一个请求而存在。因此,当您发出第二个请求时,它是空的。如果你想这样做,你应该使用它,Session或者你可以看看forms authentication

您还应该考虑 VinayC 的建议,不要以任何状态存储任何密码信息,尤其是不以明文格式存储。

于 2011-09-29T05:47:51.030 回答
1

我建议您通过 File > New 在 Visual Studio 中创建一个新的 MVC 3 项目。它将为您设置表单身份验证,因此您可以查看登录和注册页面的最佳实践,使用会话 cookie 登录/注销用户,并显示用户名等用户信息。

于 2011-09-29T06:20:25.163 回答