mirror of
				https://github.com/continew-org/continew-starter.git
				synced 2025-10-26 19:00:53 +08:00 
			
		
		
		
	fix(log): 修复构建请求可重复读流后过滤文件流导致的错误问题
This commit is contained in:
		| @@ -23,6 +23,7 @@ import jakarta.servlet.http.HttpServletRequest; | |||||||
| import org.springframework.web.util.UriUtils; | import org.springframework.web.util.UriUtils; | ||||||
| import top.continew.starter.core.constant.StringConstants; | import top.continew.starter.core.constant.StringConstants; | ||||||
| import top.continew.starter.log.http.RecordableHttpRequest; | import top.continew.starter.log.http.RecordableHttpRequest; | ||||||
|  | import top.continew.starter.web.util.RepeatReadRequestWrapper; | ||||||
|  |  | ||||||
| import java.net.URI; | import java.net.URI; | ||||||
| import java.net.URISyntaxException; | import java.net.URISyntaxException; | ||||||
| @@ -79,8 +80,11 @@ public final class RecordableServletHttpRequest implements RecordableHttpRequest | |||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public String getBody() { |     public String getBody() { | ||||||
|         String body = JakartaServletUtil.getBody(request); |         if (request instanceof RepeatReadRequestWrapper wrapper && !wrapper.isMultipartContent(request)) { | ||||||
|         return JSONUtil.isTypeJSON(body) ? body : null; |             String body = JakartaServletUtil.getBody(request); | ||||||
|  |             return JSONUtil.isTypeJSON(body) ? body : null; | ||||||
|  |         } | ||||||
|  |         return null; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|   | |||||||
| @@ -48,7 +48,13 @@ public class AccessLogUtils { | |||||||
|         } |         } | ||||||
|  |  | ||||||
|         // 参数为空返回空 |         // 参数为空返回空 | ||||||
|         Map<String, Object> params = request.getParam(); |         Map<String, Object> params; | ||||||
|  |         try { | ||||||
|  |             params = request.getParam(); | ||||||
|  |         } catch (Exception e) { | ||||||
|  |             return null; | ||||||
|  |         } | ||||||
|  |  | ||||||
|         if (ObjectUtil.isEmpty(params) || params.isEmpty()) { |         if (ObjectUtil.isEmpty(params) || params.isEmpty()) { | ||||||
|             return null; |             return null; | ||||||
|         } |         } | ||||||
|   | |||||||
| @@ -87,9 +87,9 @@ public class RepeatReadRequestWrapper extends HttpServletRequestWrapper { | |||||||
|     public BufferedReader getReader() throws IOException { |     public BufferedReader getReader() throws IOException { | ||||||
|         // 如果是文件上传,直接返回原始Reader |         // 如果是文件上传,直接返回原始Reader | ||||||
|         if (isMultipartContent(originalRequest)) { |         if (isMultipartContent(originalRequest)) { | ||||||
|             return originalRequest.getReader(); |             new BufferedReader(new InputStreamReader(originalRequest.getInputStream(), StandardCharsets.UTF_8)); | ||||||
|         } |         } | ||||||
|         return new BufferedReader(new InputStreamReader(new ByteArrayInputStream(cachedBody), StandardCharsets.UTF_8)); |         return new BufferedReader(new InputStreamReader(getInputStream())); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
| @@ -98,7 +98,7 @@ public class RepeatReadRequestWrapper extends HttpServletRequestWrapper { | |||||||
|      * @param request 请求对象 |      * @param request 请求对象 | ||||||
|      * @return 是否为文件上传请求 |      * @return 是否为文件上传请求 | ||||||
|      */ |      */ | ||||||
|     private boolean isMultipartContent(HttpServletRequest request) { |     public boolean isMultipartContent(HttpServletRequest request) { | ||||||
|         return request.getContentType() != null && request.getContentType().toLowerCase().startsWith("multipart/"); |         return request.getContentType() != null && request.getContentType().toLowerCase().startsWith("multipart/"); | ||||||
|     } |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -20,6 +20,7 @@ import jakarta.servlet.ServletOutputStream; | |||||||
| import jakarta.servlet.WriteListener; | import jakarta.servlet.WriteListener; | ||||||
| import jakarta.servlet.http.HttpServletResponse; | import jakarta.servlet.http.HttpServletResponse; | ||||||
| import jakarta.servlet.http.HttpServletResponseWrapper; | import jakarta.servlet.http.HttpServletResponseWrapper; | ||||||
|  | import org.springframework.http.MediaType; | ||||||
|  |  | ||||||
| import java.io.ByteArrayOutputStream; | import java.io.ByteArrayOutputStream; | ||||||
| import java.io.IOException; | import java.io.IOException; | ||||||
| @@ -54,7 +55,7 @@ public class RepeatReadResponseWrapper extends HttpServletResponseWrapper { | |||||||
|         // 根据 Content-Type 判断是否为流式响应 |         // 根据 Content-Type 判断是否为流式响应 | ||||||
|         if (type != null) { |         if (type != null) { | ||||||
|             String lowerType = type.toLowerCase(); |             String lowerType = type.toLowerCase(); | ||||||
|             isStreamingResponse = lowerType.contains("text/event-stream"); |             isStreamingResponse = lowerType.contains(MediaType.TEXT_EVENT_STREAM_VALUE); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -62,7 +63,7 @@ public class RepeatReadResponseWrapper extends HttpServletResponseWrapper { | |||||||
|         String contentType = getContentType(); |         String contentType = getContentType(); | ||||||
|         if (contentType != null) { |         if (contentType != null) { | ||||||
|             String lowerType = contentType.toLowerCase(); |             String lowerType = contentType.toLowerCase(); | ||||||
|             isStreamingResponse = lowerType.contains("text/event-stream"); |             isStreamingResponse = lowerType.contains(MediaType.TEXT_EVENT_STREAM_VALUE); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 liquor
					liquor