【发布时间】:2019-06-05 10:30:34
【问题描述】:
我有以下代码:
// in a service
downloadCSV(): Observable<Blob> {
return this.httpClient.get(`${apiUrl}/a.csv`, {responseType: 'blob'});
}
// in component
onDownloadClicked(event: MouseEvent) {
this.downloading = true;
this.service.downloadCSV()
.pipe(finalize(() => this.downloading = false))
.subscribe(
(data: Blob) => {
console.log(data);
},
(error) => {
console.error(error);
alert('Sorry, something wet wrong. Try again.');
},
() => {
console.log('completed!');
}
);
}
数据已正确记录但“已完成!”不会被记录,并且永远不会调用 finalize。
编辑:
所以经过进一步调查,问题似乎与添加了身份验证标头的拦截器有关。
如果拦截器被绕过(并且在服务器上禁用了身份验证),则 observable 完成且没有错误。
我不明白为什么会这样。可能与请求被克隆的事实有关?
//interceptor code
intercept(req: HttpRequest<any>, next: HttpHandler): Observable<HttpEvent<any>> {
let scope: string;
// only inject tokens for the following scopes
if (req.url.indexOf('https://graph.microsoft.com') === 0) {
scope = 'https://graph.microsoft.com';
}
else if (req.url.indexOf('https://management.azure.com') === 0) {
scope = 'https://management.azure.com';
}
else if (req.url.indexOf(environment.apiUrl) === 0) {
scope = environment.appId;
}
if (scope) {
return this.authService.getToken(scope).pipe(
switchMap((token) => {
let newReq;
if (token) {
const JWT = `Bearer ${token}`;
newReq = req.clone({
setHeaders: {
Authorization: JWT,
}
});
}
return next.handle(newReq || req);
})
);
}
else {
return next.handle(req);
}
}
【问题讨论】:
-
无法在本地复制 - 我看到在使用
{ responseType: 'blob' }和finalize在pipe中创建HttpClient#get时调用了已完成的回调。 -
按 F12 并告诉我们网络上有什么。您对此有何回应?
-
我试图创建一个堆栈闪电战。使用了所有库的相同版本,但我也无法复制它。它只适用于某人:stackblitz.com/edit/…
-
@JohnPeters 网络选项卡看起来正常,请求在那里,代码为 200,内容看起来很好。
标签: javascript angular rxjs observable angular-httpclient