这个问题是由于未正确实现Http Interceptor中的下一个处理程序而导致的,因此请求不会正确终止。为了解决这个问题,应该确保在Http Interceptor中正确调用下一个处理程序。
以下是一段示例代码,该代码使用Http Interceptor实现了JWT身份验证并调用下一个处理程序:
import { Injectable } from '@angular/core';
import { HttpEvent, HttpHandler, HttpInterceptor, HttpRequest } from '@angular/common/http';
import { AuthenticationService } from '../services/authentication.service';
import { Observable } from 'rxjs';
@Injectable()
export class JwtInterceptor implements HttpInterceptor {
constructor(private authService: AuthenticationService) {}
intercept(request: HttpRequest, next: HttpHandler): Observable> {
const currentUser = this.authService.currentUserValue;
if (currentUser && currentUser.token) {
request = request.clone({
setHeaders: {
Authorization: `Bearer ${currentUser.token}`
}
});
}
return next.handle(request);
}
}
在这个例子中,我们成功地调用了next.handle(request)
方法,确保了请求能够正确完成并返回结果。