在我的angular应用程序中,我正在寻找一种方法来处理所有服务器响应错误(弹出框显示错误消息),但允许控制器选择退出此行为,并在调用$resource时根据需要进行自己的错误处理。
我打算只使用一个拦截器,让它处理所有的错误。就像这样
$httpProvider.interceptors.push(function($q) {
return {
'responseError': function(rejection) {
displayMessage(rejection);
return $q.reject(rejection);
}
};
});然后从控制器,如果我调用
$scope.widget = WidgetResource.get();并且服务器以401错误响应,则会向用户显示一条错误消息,说明他们未获得授权。
但我突然想到,有时控制器可能想要自己处理错误响应(即,在给定的上下文中显示错误的更好方法)。有什么方法可以让它选择不做拦截器正在做的事情?
或者,拦截器可能不是解决这个问题的方法。我还能用什么来处理这种横切关注点,并允许选择退出?
发布于 2014-03-02 02:56:02
您可以使用拦截器来处理与上下文无关的错误。我们发现这实际上是一种很好的做法。会话超时(401)或内部服务器错误(500)之类的错误可以由拦截器处理。而特定于上下文的错误在它们各自的服务回调中得到更好的处理。
您可以通过以下方式根据HTTP status codes进行区分:
function responseError(rejection) {
switch (rejection.status) {
case 401:
//handle unauthenticated request
case 500:
//Oops something has gone wrong due to an internal server error
default:
break;
}
return $q.reject(rejection);
}在$q.reject(rejection)时,控制被转发给相应$resource实例的错误处理程序。因此,在上面的示例中,来自服务器的404将被转发到您各自的控制器或服务的错误处理程序。
https://stackoverflow.com/questions/22118377
复制相似问题