要获取原始的HTTP响应,包括在发生错误时,可以使用Angular HttpClient的observe
选项。通过将observe
选项设置为'response'
,可以访问完整的HTTP响应,而不仅仅是响应的主体。
以下是一个使用observe
选项的示例代码:
import { HttpClient, HttpErrorResponse, HttpResponse } from '@angular/common/http';
constructor(private http: HttpClient) {}
fetchData() {
this.http.get('https://api.example.com/data', { observe: 'response' })
.subscribe(
(response: HttpResponse) => {
console.log('HTTP响应:', response);
console.log('响应主体:', response.body);
},
(error: HttpErrorResponse) => {
console.error('HTTP错误:', error);
}
);
}
在上面的示例中,fetchData
方法使用get
方法从https://api.example.com/data
获取数据。通过将observe
选项设置为'response'
,可以访问完整的HTTP响应对象。
在成功的情况下,subscribe
函数的第一个参数将包含HttpResponse
对象,其中包含响应的各种属性,如头部、状态码和响应主体。
在发生错误的情况下,subscribe
函数的第二个参数将包含HttpErrorResponse
对象,其中包含有关错误的详细信息,如错误消息和状态码。
请注意,使用observe
选项时,HttpClient
默认情况下不会将响应转换为JSON对象。如果您希望直接获得JSON响应主体,请使用response.body
来访问它。