Commit b3f94c47 authored by wenqi.huang's avatar wenqi.huang Committed by Stephane Nicoll

Cache MimeTypes to improve performance

See gh-16507
parent 0875a07f
......@@ -17,7 +17,9 @@
package org.springframework.boot.web.embedded.netty;
import java.util.Arrays;
import java.util.List;
import java.util.function.BiPredicate;
import java.util.stream.Collectors;
import io.netty.handler.codec.http.HttpHeaderNames;
import io.netty.handler.codec.http.HttpHeaders;
......@@ -67,6 +69,10 @@ final class CompressionCustomizer implements NettyServerCustomizer {
if (ObjectUtils.isEmpty(mimeTypes)) {
return ALWAYS_COMPRESS;
}
List<MimeType> mimeTypeList = Arrays.stream(mimeTypes)
.map(MimeTypeUtils::parseMimeType).collect(Collectors.toList());
return (request, response) -> {
String contentType = response.responseHeaders()
.get(HttpHeaderNames.CONTENT_TYPE);
......@@ -74,7 +80,7 @@ final class CompressionCustomizer implements NettyServerCustomizer {
return false;
}
MimeType contentMimeType = MimeTypeUtils.parseMimeType(contentType);
return Arrays.stream(mimeTypes).map(MimeTypeUtils::parseMimeType)
return mimeTypeList.stream()
.anyMatch((candidate) -> candidate.isCompatibleWith(contentMimeType));
};
}
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment