fix: 解决html页面缓存的问题。

This commit is contained in:
liqiang-fit2cloud 2022-11-16 12:35:20 +08:00
parent fff50fb038
commit e7fe6e5d4e
1 changed files with 25 additions and 4 deletions

View File

@ -1,25 +1,33 @@
package io.metersphere.gateway.filter;
import io.metersphere.commons.utils.LogUtil;
import org.apache.commons.lang3.StringUtils;
import org.springframework.cloud.gateway.filter.GatewayFilter;
import org.springframework.cloud.gateway.filter.GatewayFilterChain;
import org.springframework.core.Ordered;
import org.springframework.http.HttpHeaders;
import org.springframework.http.HttpMethod;
import org.springframework.http.HttpStatus;
import org.springframework.http.MediaType;
import org.springframework.http.server.reactive.ServerHttpResponse;
import org.springframework.stereotype.Component;
import org.springframework.web.server.ServerWebExchange;
import reactor.core.publisher.Mono;
import java.net.URI;
import java.util.HashMap;
import static org.springframework.cloud.gateway.support.ServerWebExchangeUtils.GATEWAY_REQUEST_URL_ATTR;
@Component
public class HtmlResourceFilter implements GatewayFilter, Ordered {
private static final String HTTP_SCHEME = "http";
private static final HashMap<String, String> NoCacheHeaders = new HashMap<>();
static {
NoCacheHeaders.put(HttpHeaders.CACHE_CONTROL, "no-cache, no-store, must-revalidate");
NoCacheHeaders.put(HttpHeaders.CACHE_CONTROL, "no-cache");
NoCacheHeaders.put("Cache", "no-cache");
NoCacheHeaders.put(HttpHeaders.PRAGMA, "no-cache");
NoCacheHeaders.put(HttpHeaders.EXPIRES, "0");
}
@ -28,10 +36,23 @@ public class HtmlResourceFilter implements GatewayFilter, Ordered {
public Mono<Void> filter(ServerWebExchange exchange, GatewayFilterChain chain) {
return chain.filter(exchange).then(
Mono.fromRunnable(() -> {
URI requestUrl = exchange.getRequiredAttribute(GATEWAY_REQUEST_URL_ATTR);
if (!StringUtils.startsWithIgnoreCase(requestUrl.getScheme(), HTTP_SCHEME)) {
// maybe ws or wss instead of http?
return;
}
try {
ServerHttpResponse response = exchange.getResponse();
if (exchange.getRequest().getMethod() == HttpMethod.GET && response.getHeaders().getContentType() == MediaType.TEXT_HTML) {
if (response == null) {
// maybe backend service is unavailable or other scenario?
return;
}
if (exchange.getRequest().getMethod() == HttpMethod.GET && response.getHeaders().getContentType() == MediaType.TEXT_HTML && response.getStatusCode() == HttpStatus.OK) {
response.getHeaders().setAll(NoCacheHeaders);
}
} catch (Exception e) {
LogUtil.error("Fail to handle url " + requestUrl.getPath(), e);
}
})
);
}