【发布时间】:2014-06-04 13:35:00
【问题描述】:
我以用户身份成功登录,然后该用户能够访问网站的 [已授权] 部分。用户名甚至显示在站点的右上角,因为它们已成功通过身份验证。但是,当我尝试在帖子中获取用户身份以进行新事件时,用户为空。
这是我的登录服务:
login.service('loginService', function ($http, $q) {
var deferred = $q.defer();
this.signin = function (user) {
var config = {
headers: {
'Content-Type': 'application/x-www-form-urlencoded'
}
}
$http.post('Token', 'grant_type=password&username='+user.UserName+'&password='+user.Password, config)
.success(function (data) {
window.location = "/dashboard";
}).error(function (error) {
deferred.reject(error);
});
return deferred.promise;
}
});
这是我发布新活动的帖子
[Route("post")]
public HttpResponseMessage PostEvent(EventEditModel ev)
{
if (!ModelState.IsValid)
{
return Request.CreateErrorResponse(HttpStatusCode.InternalServerError, "{ }");
}
try
{
Event DBEvent;
if (ev.EventId > 0)
{
DBEvent = db.Events.Find(ev.EventId);
DBEvent.ModifiedBy = Guid.Parse(User.Identity.GetUserId());
DBEvent.ModifiedOn = DateTime.Now;
}
else
{
DBEvent = new Event();
string id = User.Identity.GetUserId();
DBEvent.CreatedBy = Guid.Parse(User.Identity.GetUserId());
DBEvent.CreatedOn = DateTime.Now;
}
...
}
我应该在每个帖子中传递用户信息吗?我不知道我会怎么做。还是我只是没有正确登录用户?
【问题讨论】:
-
您好像忘记在成功回调中调用
deferred.resolve(data); -
@KhanhTO 谢谢。可能解决了未来的头痛问题,但这仍然没有解决。如果成功,我应该对那个回报做些什么吗?
标签: c# angularjs asp.net-web-api