angular - Angular 中的通用 http 错误处理

标签 angular http error-handling dry angular2-jwt

angular2-jwt为原生 Angular http 类提供 AuthHttp 包装器,该类会自动在每个请求中包含 http 授权 header 。在我的服务中,我通常调用这样的后端 api

  getThings(): Observable<Thing[]> {
    return this.http.get(environment.apiEndpoint + '/things')
                    .map(res => res.json().data)
                    .catch(res => this.handleError(res));
  }

带有错误处理程序,例如

private handleError(error: Response | any) {
  let errMsg: string;
  if (error instanceof Response) {
    const body = error.json() || '';
    const err = body.error || JSON.stringify(body);
    errMsg = `${error.status} - ${error.statusText || ''} ${err}`;
  } else {
    errMsg = error.message ? error.message : error.toString();
  }
  // If JWT is expired open a new window to log in again
  if (errMsg.indexOf('No JWT present or has expired') !== -1) {
    window.open(environment.apiEndpoint + '/loginToApp?expired', '_blank', 'height=570,width=520');
  }
  console.error(error);
  return Observable.throw(errMsg);
}

我在所有服务中不断重复handleError方法,我想知道是否有办法让这个DRY。有没有办法为所有 http 请求定义通用错误处理程序?

如果可能的话,我想避免每次都调用catch。有没有办法扩展 http 类以自动捕获每个请求的错误,然后在特殊情况下我可以根据具体情况添加自定义捕获逻辑?

我可以从另一个文件导出该方法并将其导入到我的每个服务中,但我认为必须有更好的方法。感谢您的任何建议。

更新:我最终从 angular2-jwt 扩展了 AuthHttp 类。

import { Http, RequestOptions, Response, Request, RequestOptionsArgs } from '@angular/http';

import { Observable } from 'rxjs/Observable';
import 'rxjs/add/operator/catch';
import 'rxjs/add/observable/throw';

import { AuthHttp, AuthConfig } from 'angular2-jwt';

export class ApiHttp extends AuthHttp { 

  public request(url: string | Request, options?: RequestOptionsArgs): Observable<Response> {
    return super.request(url, options).catch(res => this.handleError(res));
  }

  private handleError(error: Response | any) {
    // error handling then rethrow the error
    return Observable.throw(error);
  }
}

最佳答案

您可以像 AuthHTTP Wrapper 一样创建自定义服务 CustomAuthHttp。就像包装器添加 header 一样,在 CustomAuthHttp 中您可以捕获错误。然后在您的代码中注入(inject) CustomAuthHttp 而不是 AuthHTTP 并使用。

@Injectable()
export class CustomAuthHttp {

  constructor(private http: AuthHttpWrapper) { }

  get(url: string) {
    return this.http.get(url)
      .catch(res => this.handleError(res));
  }

  private handleError(error: Response | any) {
    // your code
    return Observable.throw('');
  }
}

关于angular - Angular 中的通用 http 错误处理,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44929046/

相关文章:

python - 如何使用 Python 查找(和抓取)给定域中的所有网页?

ruby-on-rails - 有没有办法让控制台忽略某些错误?

asp.net - 同时使用ELMAH和Application_Error

security - HTTP 拆分和 HTTP 走私之间的区别?

http - 在 HTTP 响应 header 中使用 content-disposition

javascript - 如果用户尝试删除未找到的记录,服务器应该返回 200 还是 404?

javascript - Angular 2 接口(interface)

angular - 服务器端不呈现 http 请求 [Angular Universal]

angular - 从 "angularfire2/database"导入 { AngularFireDatabase, FirebaseListObservable } ;

Angular 组件未在 Internet Explorer 11 上显示