我有一些Kendo MVC网格绑定到远程Json控制器操作,这些操作非常有效。 MVC应用程序使用自定义AuthorizeAttribute来授权访问控制器操作,当用户未经过身份验证时,它会回复302重定向到登录页面。 一切都很好,除了当会话到期时,数据源读取调用会在收到重定向响应而不是预期数据时静默失败。 我已经尝试在数据源的错误事件处理程序中处理这种情况,但在这种情况下不会调用处理程序。
这是错误处理程序:
function childGrid_error(e, gridName) {
if (e.xhr.status === 302)
location.reload();
else
if (e.errors) {
var message = "";
$.each(e.errors, function (key, value) {
if ('errors' in value) {
$.each(value.errors, function () {
message += this + "\n";
});
}
});
kendoAlert(message);
var grid = $(gridName).data("kendoGrid");
grid.cancelChanges();
}
}
这是一个剑道数据源,采用Razor语法:
.DataSource(ds => ds
.Ajax()
.Model(m => m.Id(c => c.Id))
.Sort(s=>s.Add(f=>f.Username))
.PageSize(10)
.Events(e => e.Error("function(e) { grid_error(e, \"UsersGrid\");}"))
.Read("GetUsers", "Admin")
.Create("PutUser", "Admin")
.Destroy("DeleteUser", "Admin")
.Update("UpdateUser", "Admin"))
关于此错误处理程序,我是否遗漏了一些内容?
答案 0 :(得分:0)
事实证明,浏览器会自动跟随xhr上的重定向,而kendo数据源无法以任何方式知道这一点。由于重定向返回200状态代码,因此错误处理程序根本不会被触发。在我看来,由于响应绝不是json格式,并且不可能被数据源绑定,因此错误处理程序应该被kendo数据源触发。
总之...
我的解决方案是修改自定义AuthorizeAttribute以返回401(未授权)状态代码,但仅针对ajax请求。这样,数据源错误处理程序将被调用,并能够对过期的会话问题做出反应。
自定义AuthorizeAttribute中的相关代码:
if (filterContext.HttpContext.Request.IsAjaxRequest())
filterContext.Result = new HttpStatusCodeResult(System.Net.HttpStatusCode.Unauthorized);
else
filterContext.Result = new RedirectToRouteResult(new RouteValueDictionary(new { controller = "Auth", action = "Login" }));
这就是数据源错误处理程序现在的样子:
function childGrid_error(e, gridName) {
if (e.xhr.status === 401) //Unauthorized
location.reload();
else
if (e.errors) {
var message = "";
$.each(e.errors, function (key, value) {
if ('errors' in value) {
$.each(value.errors, function () {
message += this + "\n";
});
}
});
kendoAlert(message);
var grid = $(gridName).data("kendoGrid");
grid.cancelChanges();
}
}
location.reload()
位实际上进行了页面刷新,并将浏览器置于正常的身份验证工作流程中。