首页 > 解决方案 > 以角度全局处理 HTTP 错误

问题描述

我正在从事http 错误处理。我已经在每个组件中编写了错误处理,这不是一个好的编码实践。所以我决定写一个全局通用的http错误处理。我已经搜索过了,我遇到了http-interceptor概念,我认为存在更好的方法来处理HTTP错误。我在每个组件中尝试过的内容如下,而不是我需要一个全局方法。我已经有 http-interceptor 文件,代码是我在下面粘贴的。

组件.ts:

this.serviceName.methodName().catch(err => {
  console.log("Something went wrong with the request, please try again.");
  return Observable.throw(err.message.toUpperCase() || 'API_ERROR');
}).subscribe((res) => {
   console.log(res);
},
 error=>{
    this.openSnackBar('danger', "Something went wrong with the request, please try again.");
 });

http拦截器:

import { Injectable } from "@angular/core";
import { HttpInterceptor, HttpRequest, HttpHandler, HttpEvent, HttpResponse } from "@angular/common/http";
import { Observable } from "rxjs";
import { tap } from 'rxjs/operators';

@Injectable()
export class HttpErrorInterceptor implements HttpInterceptor {
constructor() { }

intercept(request: HttpRequest<any>, next: HttpHandler): Observable<HttpEvent<any>> {
    return next.handle(request).pipe(tap(
        event => event instanceof HttpResponse ? 'succeeded' : '',
        err => 'failed'
    ))
 }
}

请帮忙。谢谢。

标签: angularhttp-error

解决方案


试试这个:

intercept(request: HttpRequest<any>, next: HttpHandler): Observable<HttpEvent<any>> {
    return next.handle(request).pipe(tap(
      event => event instanceof HttpResponse ? 'succeeded' : '',
      err => {
        this.openSnackBar('danger', "Something went wrong with the request, please try again.");
      }
    ))
  }

推荐阅读