[英]Angular2 IE11 caching issue
每当我在IE上执行简单的CORS获取请求时,都会遇到缓存问题。 在Chrome上不会发生这种情况。 所以我不得不在获取请求时添加选项:
let options = new RequestOptions({
url: this.elementsUrl,
method: RequestMethod.Get,
headers: this.getHeaders
});
return this.http.get(this.elementsUrl, options)
.map(response => response.json())
.catch(error => {
console.error('Error', error);
return Promise.reject(error.message || error);
}
);
我设置头以禁用缓存。
private _getHeaders = new Headers({
'If-Modified-Since': 'Mon, 26 Jul 1997 05:00:00 GMT',
'Cache-Control': 'no-cache',
'Pragma': 'no-cache'
});
现在,我正在获取所需的信息:CORS预检和XMLHttpRequest:网络错误0x80070005,访问被拒绝。 我可以避免触发飞行前选项吗? 我是否正确设置选项?
它仅与IE缓存GET请求有关。 CORS在chrome上运行正常。 在服务器端设置:Access-Control-Allow-Origin:*
在服务器端,如果是JAVA,我创建了一个过滤器,如下所示
@PreMatching
@Provider
public class GwsApiCorsFilter implements ContainerRequestFilter {
@Override
public void filter(ContainerRequestContext requestContext, ContainerResponseContext responseContext)
throws IOException {
responseContext.getHeaders().add("Access-Control-Allow-Origin", "*");
responseContext.getHeaders().add("Access-Control-Allow-Methods", "GET, POST, DELETE, PUT, PATCH");
responseContext.getHeaders().add("Access-Control-Allow-Headers", getAllowedHeaders());
responseContext.getHeaders().add("Access-Control-Expose-Headers", getAllowedHeaders());
}
private String getAllowedHeaders() {
StringBuilder sb = new StringBuilder();
sb.append(HttpHeaders.ACCEPT).append(", ")
.append(HttpHeaders.CONTENT_TYPE).append(", ")
.append(HttpHeaders.AUTHORIZATION).append(", ")
.append(HEADER_IF_MODIFIED_SINCE).append(", ")
.append(HEADER_CACHE_CONTROL).append(", ")
.append(HEADER_PRAGMA).append(", ")
.append(HEADER_CONTENT_DISPOSITION).append(", ");
return sb.toString();
}
}
并在客户端使用以下教程在角度工具http拦截器中
https://scotch.io/@kashyapmukkamala/using-http-interceptor-with-angular2
将请求中的所有标头添加到私有getRequestOptionArgs(options?: RequestOptionsArgs) : RequestOptionsArgs {}
函数
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.