所以我实现了我自己的自定义会员提供程序,目前只覆盖了ValidateUser()。我也有信号器工作,目前只是一个简单的方法,它调用发送消息,然后将其发送给所有听众。我想添加一些验证检查,以便该命令不能单独运行。到目前为止,我发现您可以使用以下方法执行此操作:Context.User.Identity.IsAuthenticated
[HubName("messageController")]
public class MessageController : Hub
{
public void SendMessage(string message)
{
if (Context.User.Identity.IsAuthenticated) // this line not working
{
Clients.addMessage(message);
}
else
{
Clients.addMessage("not authenticated");
}
}
}
不过,我的问题是因为我目前使用的自定义会员提供程序值为 false。还有什么我应该在这里使用的吗?
目前,当我登录时,我执行:
[AllowAnonymous]
[HttpPost]
public ActionResult Login(LoginModel model, string returnUrl)
{
if(Membership.ValidateUser(model.UserName, model.Password))
{
// Need something here to actually set the logged in user
}
return RedirectToAction("Index", "");
}
我在这里想念什么?我是否需要存储自己的代码来处理会话,我尝试使用FormsAuthentication.SetAuthCookie(model.UserName, true);
哪个有效,但我很确定它是错误的。当我试图通过将角色更改为它来引入角色时,Context.User.IsInRole("Admin")
它返回了 false。即使我使用了以下用户模型(调试时从未使用此方法):
public class User : IPrincipal
{
[Required]
[Display(Name = "User name")]
public string UserName { get; set; }
[Required]
[DataType(DataType.Password)]
[Display(Name = "Password")]
public string Password { get; set; }
public long UserID;
public string Name;
public string ConnectionId;
public virtual IIdentity Identity
{
get;
set;
}
public virtual bool IsInRole(string role)
{
return true;
}
}
我很有信心我错过了一些东西,有什么想法吗?