From 0d0f70bf15e7e49ab64d024173f559146781f4c5 Mon Sep 17 00:00:00 2001 From: duandazhi Date: Wed, 24 Mar 2021 15:21:23 +0800 Subject: [PATCH] =?UTF-8?q?add=20ServletUtil=20=E6=B5=8B=E8=AF=95=E8=BF=9D?= =?UTF-8?q?=E5=8F=8D=E6=B3=95=20=E5=92=8C=20=E6=B3=A8=E9=87=8A=EF=BC=9B?= =?UTF-8?q?=E6=96=B9=E4=BE=BF=E8=B0=83=E7=94=A8=E8=BF=99=E8=BF=9B=E8=A1=8C?= =?UTF-8?q?=E8=B0=83=E7=94=A8=EF=BC=9B=20=E7=9B=AE=E5=89=8D=E6=9A=82?= =?UTF-8?q?=E6=97=B6=E5=8F=91=E7=8E=B0=EF=BC=9Asafafi=E6=B5=8F=E8=A7=88?= =?UTF-8?q?=E5=99=A8=E5=87=BA=E7=8E=B0=E4=B9=B1=E7=A0=81?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../cn/hutool/extra/servlet/ServletUtil.java | 97 +++++++++++-------- .../hutool/extra/servlet/ServletUtilTest.java | 30 ++++++ 2 files changed, 84 insertions(+), 43 deletions(-) create mode 100644 hutool-extra/src/test/java/cn/hutool/extra/servlet/ServletUtilTest.java diff --git a/hutool-extra/src/main/java/cn/hutool/extra/servlet/ServletUtil.java b/hutool-extra/src/main/java/cn/hutool/extra/servlet/ServletUtil.java index 5a2e83ecb..cc61981ef 100644 --- a/hutool-extra/src/main/java/cn/hutool/extra/servlet/ServletUtil.java +++ b/hutool-extra/src/main/java/cn/hutool/extra/servlet/ServletUtil.java @@ -43,7 +43,7 @@ import java.util.Map; /** * Servlet相关工具类封装 - * + * * @author looly * @since 3.2.0 */ @@ -60,7 +60,7 @@ public class ServletUtil { // --------------------------------------------------------- getParam start /** * 获得所有请求参数 - * + * * @param request 请求对象{@link ServletRequest} * @return Map */ @@ -71,7 +71,7 @@ public class ServletUtil { /** * 获得所有请求参数 - * + * * @param request 请求对象{@link ServletRequest} * @return Map */ @@ -86,7 +86,7 @@ public class ServletUtil { /** * 获取请求体
* 调用该方法后,getParam方法将失效 - * + * * @param request {@link ServletRequest} * @return 获得请求体 * @since 4.0.2 @@ -102,7 +102,7 @@ public class ServletUtil { /** * 获取请求体byte[]
* 调用该方法后,getParam方法将失效 - * + * * @param request {@link ServletRequest} * @return 获得请求体byte[] * @since 4.0.2 @@ -119,7 +119,7 @@ public class ServletUtil { // --------------------------------------------------------- fillBean start /** * ServletRequest 参数转Bean - * + * * @param Bean类型 * @param request ServletRequest * @param bean Bean @@ -159,7 +159,7 @@ public class ServletUtil { /** * ServletRequest 参数转Bean - * + * * @param Bean类型 * @param request {@link ServletRequest} * @param bean Bean @@ -172,7 +172,7 @@ public class ServletUtil { /** * ServletRequest 参数转Bean - * + * * @param Bean类型 * @param request ServletRequest * @param beanClass Bean Class @@ -186,10 +186,10 @@ public class ServletUtil { /** * 获取客户端IP - * + * *

* 默认检测的Header: - * + * *

 	 * 1、X-Forwarded-For
 	 * 2、X-Real-IP
@@ -201,7 +201,7 @@ public class ServletUtil {
 	 * otherHeaderNames参数用于自定义检测的Header
* 需要注意的是,使用此方法获取的客户IP地址必须在Http服务器(例如Nginx)中配置头信息,否则容易造成IP伪造。 *

- * + * * @param request 请求对象{@link HttpServletRequest} * @param otherHeaderNames 其他自定义头文件,通常在Http服务器(例如Nginx)中配置 * @return IP地址 @@ -214,15 +214,15 @@ public class ServletUtil { return getClientIPByHeader(request, headers); } - + /** * 获取客户端IP - * + * *

* headerNames参数用于自定义检测的Header
* 需要注意的是,使用此方法获取的客户IP地址必须在Http服务器(例如Nginx)中配置头信息,否则容易造成IP伪造。 *

- * + * * @param request 请求对象{@link HttpServletRequest} * @param headerNames 自定义头,通常在Http服务器(例如Nginx)中配置 * @return IP地址 @@ -243,7 +243,7 @@ public class ServletUtil { /** * 获得MultiPart表单内容,多用于获得上传的文件 在同一次请求中,此方法只能被执行一次! - * + * * @param request {@link ServletRequest} * @return MultipartFormData * @throws IORuntimeException IO异常 @@ -257,7 +257,7 @@ public class ServletUtil { * 获得multipart/form-data 表单内容
* 包括文件和普通表单数据
* 在同一次请求中,此方法只能被执行一次! - * + * * @param request {@link ServletRequest} * @param uploadSetting 上传文件的设定,包括最大文件大小、保存在内存的边界大小、临时目录、扩展名限定等 * @return MultiPart表单 @@ -278,28 +278,28 @@ public class ServletUtil { // --------------------------------------------------------- Header start /** * 获取请求所有的头(header)信息 - * + * * @param request 请求对象{@link HttpServletRequest} * @return header值 * @since 4.6.2 */ public static Map getHeaderMap(HttpServletRequest request) { final Map headerMap = new HashMap<>(); - + final Enumeration names = request.getHeaderNames(); String name; while (names.hasMoreElements()) { name = names.nextElement(); headerMap.put(name, request.getHeader(name)); } - + return headerMap; } - - + + /** * 忽略大小写获得请求header中的信息 - * + * * @param request 请求对象{@link HttpServletRequest} * @param nameIgnoreCase 忽略大小写头信息的KEY * @return header值 @@ -316,10 +316,10 @@ public class ServletUtil { return null; } - + /** * 获得请求header中的信息 - * + * * @param request 请求对象{@link HttpServletRequest} * @param name 头信息的KEY * @param charsetName 字符集 @@ -331,7 +331,7 @@ public class ServletUtil { /** * 获得请求header中的信息 - * + * * @param request 请求对象{@link HttpServletRequest} * @param name 头信息的KEY * @param charset 字符集 @@ -348,7 +348,7 @@ public class ServletUtil { /** * 客户浏览器是否为IE - * + * * @param request 请求对象{@link HttpServletRequest} * @return 客户浏览器是否为IE */ @@ -364,7 +364,7 @@ public class ServletUtil { /** * 是否为GET请求 - * + * * @param request 请求对象{@link HttpServletRequest} * @return 是否为GET请求 */ @@ -374,7 +374,7 @@ public class ServletUtil { /** * 是否为POST请求 - * + * * @param request 请求对象{@link HttpServletRequest} * @return 是否为POST请求 */ @@ -384,7 +384,7 @@ public class ServletUtil { /** * 是否为Multipart类型表单,此类型表单用于文件上传 - * + * * @param request 请求对象{@link HttpServletRequest} * @return 是否为Multipart类型表单,此类型表单用于文件上传 */ @@ -404,7 +404,7 @@ public class ServletUtil { // --------------------------------------------------------- Cookie start /** * 获得指定的Cookie - * + * * @param httpServletRequest {@link HttpServletRequest} * @param name cookie名 * @return Cookie对象 @@ -415,7 +415,7 @@ public class ServletUtil { /** * 将cookie封装到Map里面 - * + * * @param httpServletRequest {@link HttpServletRequest} * @return Cookie map */ @@ -433,7 +433,7 @@ public class ServletUtil { /** * 设定返回给客户端的Cookie - * + * * @param response 响应对象{@link HttpServletResponse} * @param cookie Servlet Cookie对象 */ @@ -443,7 +443,7 @@ public class ServletUtil { /** * 设定返回给客户端的Cookie - * + * * @param response 响应对象{@link HttpServletResponse} * @param name Cookie名 * @param value Cookie值 @@ -454,7 +454,7 @@ public class ServletUtil { /** * 设定返回给客户端的Cookie - * + * * @param response 响应对象{@link HttpServletResponse} * @param name cookie名 * @param value cookie值 @@ -476,7 +476,7 @@ public class ServletUtil { * 设定返回给客户端的Cookie
* Path: "/"
* No Domain - * + * * @param response 响应对象{@link HttpServletResponse} * @param name cookie名 * @param value cookie值 @@ -490,7 +490,7 @@ public class ServletUtil { // --------------------------------------------------------- Response start /** * 获得PrintWriter - * + * * @param response 响应对象{@link HttpServletResponse} * @return 获得PrintWriter * @throws IORuntimeException IO异常 @@ -505,7 +505,7 @@ public class ServletUtil { /** * 返回数据给客户端 - * + * * @param response 响应对象{@link HttpServletResponse} * @param text 返回的内容 * @param contentType 返回的类型 @@ -526,7 +526,7 @@ public class ServletUtil { /** * 返回文件给客户端 - * + * * @param response 响应对象{@link HttpServletResponse} * @param file 写出的文件对象 * @since 4.1.15 @@ -545,10 +545,21 @@ public class ServletUtil { /** * 返回数据给客户端 - * + * * @param response 响应对象{@link HttpServletResponse} * @param in 需要返回客户端的内容 * @param contentType 返回的类型 + * 如: + * 1、application/pdf、 + * 2、application/vnd.ms-excel、 + * 3、application/msword、 + * 4、application/vnd.ms-powerpoint + * docx、xlsx 这种 office 2007 格式 设置 MIME;网页里面docx 文件是没问题,但是下载下来了之后就变成doc格式了 + * https://blog.csdn.net/cyh2260629/article/details/73824760 + * 5、MIME_EXCELX_TYPE = "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet"; + * 6、MIME_PPTX_TYPE = "application/vnd.openxmlformats-officedocument.presentationml.presentation"; + * 7、MIME_WORDX_TYPE = "application/vnd.openxmlformats-officedocument.wordprocessingml.document"; + * 8、MIME_STREAM_TYPE = "application/octet-stream;charset=utf-8"; #原始字节流 * @param fileName 文件名 * @since 4.1.15 */ @@ -561,7 +572,7 @@ public class ServletUtil { /** * 返回数据给客户端 - * + * * @param response 响应对象{@link HttpServletResponse} * @param in 需要返回客户端的内容 * @param contentType 返回的类型 @@ -573,7 +584,7 @@ public class ServletUtil { /** * 返回数据给客户端 - * + * * @param response 响应对象{@link HttpServletResponse} * @param in 需要返回客户端的内容 */ @@ -583,7 +594,7 @@ public class ServletUtil { /** * 返回数据给客户端 - * + * * @param response 响应对象{@link HttpServletResponse} * @param in 需要返回客户端的内容 * @param bufferSize 缓存大小 @@ -603,7 +614,7 @@ public class ServletUtil { /** * 设置响应的Header - * + * * @param response 响应对象{@link HttpServletResponse} * @param name 名 * @param value 值,可以是String,Date, int diff --git a/hutool-extra/src/test/java/cn/hutool/extra/servlet/ServletUtilTest.java b/hutool-extra/src/test/java/cn/hutool/extra/servlet/ServletUtilTest.java new file mode 100644 index 000000000..020557746 --- /dev/null +++ b/hutool-extra/src/test/java/cn/hutool/extra/servlet/ServletUtilTest.java @@ -0,0 +1,30 @@ +package cn.hutool.extra.servlet; + +import org.junit.Test; + +import javax.servlet.http.HttpServletResponse; +import java.io.ByteArrayInputStream; +import java.nio.charset.StandardCharsets; + +/** + * ServletUtil工具类测试 + * @author dazer + * @date 2021/3/24 15:02 + * @see ServletUtil + */ +public class ServletUtilTest { + @Test + public void writeTest() { + HttpServletResponse response = null; + byte[] bytes = new String("地球是我们共同的家园,需要大家珍惜.").getBytes(StandardCharsets.UTF_8); + + //下载文件 + // 这里没法直接测试,直接写到这里,方便调用; + if (response != null) { + String fileName = "签名文件.pdf"; + String contentType = "application/pdf";// application/octet-stream、 + response.setCharacterEncoding(StandardCharsets.UTF_8.name()); // 必须设置否则乱码; 但是 safari乱码 + ServletUtil.write(response, new ByteArrayInputStream(bytes), contentType, fileName); + } + } +}