赞
踩
在Angular的HTTP拦截器中,如果你希望在特定条件下阻止请求继续进行并中断请求链,直接返回 false
实际上不会达到预期效果。Angular的HTTP拦截器期望拦截器方法 intercept
返回一个 Observable<HttpEvent<any>>
。如果你想要中断请求,应该抛出一个错误或者返回一个错误的 Observable
。
例如,如果你在拦截器中判断到请求不符合要求,可以通过抛出错误或返回一个带有错误信息的 Observable
来中断请求
- import { Injectable } from '@angular/core';
- import { HttpRequest, HttpHandler, HttpEvent, HttpInterceptor, HttpErrorResponse } from '@angular/common/http';
- import { Observable, throwError } from 'rxjs';
- import { catchError } from 'rxjs/operators';
-
- @Injectable()
- export class MyInterceptor implements HttpInterceptor {
-
- intercept(request: HttpRequest<any>, next: HttpHandler): Observable<HttpEvent<any>> {
- // 假设我们有一些条件判断
- if (/* 不符合要求的条件 */) {
- // 抛出错误,中断请求
- return throwError(new HttpErrorResponse({ status: 403, statusText: 'Forbidden by Interceptor' }));
- }
-
- // 如果条件符合,继续处理请求
- return next.handle(request).pipe(
- catchError(error => {
- // 可以在这里处理错误,决定是否重新抛出或转换错误
- return throwError(error);
- })
- );
- }
- }
在这个例子中,如果请求不符合你的要求,拦截器会抛出一个 HttpErrorResponse
,模拟一个HTTP错误响应,从而中断请求流程。这会使得请求不会到达服务器,而且错误可以通过订阅的错误处理逻辑来捕获。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。