asp.net mvc保持对象活着,信息

时间:2011-09-29 05:28:21

标签: asp.net-mvc asp.net-mvc-3 asp.net-mvc-4

我有这个代码

[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 个答案:

答案 0 :(得分: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也适用于新的标签/ Windows,就像Session变量一样。

您也可以使用Session变量,唯一的问题是Session变量与TempData相比非常重。最后,您还可以在控制器/区域之间保留数据。

希望这篇文章可以帮到你。

答案 1 :(得分: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. 解释解决方案,以便您不必对每个操作应用授权属性 - http://blogs.msdn.com/b/rickandy/archive/2011/05/02/securing-your-asp-net-mvc-3-application.aspx

答案 2 :(得分:1)

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

您还应该考虑VinayC建议,不要在任何州存储任何密码信息,特别是不能以明文格式存储。

答案 3 :(得分:1)

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

相关问题