14《hutool实战》:ResourceUtil 资源工具(JAVA 小虚竹)

x33g5p2x  于2022-02-09 转载在 Java  
字(7.9k)|赞(0)|评价(0)|浏览(847)

❤️作者主页:小虚竹

❤️作者简介:大家好,我是小虚竹。Java领域优质创作者🏆,CSDN博客专家🏆,华为云享专家🏆,掘金年度人气作者🏆,阿里云专家博主🏆

❤️技术活,该赏

❤️点赞 👍 收藏 ⭐再看,养成习惯

用途:ResourceUtil 资源工具

使用场景

资源工具类:可以用来读取Classpath下的资源和获取指定路径下的资源列表;

方法摘要

方法描述
cn.hutool.core.io.resource.ResourceUtil.readUtf8Str(java.lang.String)读取Classpath下的资源为字符串,使用UTF-8编码
cn.hutool.core.io.resource.ResourceUtil.readStr(java.lang.String, java.nio.charset.Charset)读取Classpath下的资源为字符串
cn.hutool.core.io.resource.ResourceUtil.readBytes(java.lang.String)读取Classpath下的资源为byte[]
cn.hutool.core.io.resource.ResourceUtil.getStream(java.lang.String)从ClassPath资源中获取{@link InputStream}
cn.hutool.core.io.resource.ResourceUtil.getStreamSafe(java.lang.String)从ClassPath资源中获取{@link InputStream},当资源不存在时返回null
cn.hutool.core.io.resource.ResourceUtil.getUtf8Reader(java.lang.String)从ClassPath资源中获取{@link BufferedReader}
cn.hutool.core.io.resource.ResourceUtil.getReader(java.lang.String, java.nio.charset.Charset)从ClassPath资源中获取{@link BufferedReader}
cn.hutool.core.io.resource.ResourceUtil.getResource(java.lang.String)获得资源的URL<br> 路径用/分隔,例如:
  1. config/a/db.config spring/xml/test.xml

|
| cn.hutool.core.io.resource.ResourceUtil.getResources(java.lang.String) | 获取指定路径下的资源列表<br> 路径格式必须为目录格式,用/分隔,例如:

  1. config/a spring/xml

|
| cn.hutool.core.io.resource.ResourceUtil.getResourceIter(java.lang.String) | 获取指定路径下的资源Iterator<br> 路径格式必须为目录格式,用/分隔,例如:

  1. config/a spring/xml

|
| cn.hutool.core.io.resource.ResourceUtil.getResource(java.lang.String, java.lang.Class) | 获得资源相对路径对应的URL |
| cn.hutool.core.io.resource.ResourceUtil.getResourceObj(java.lang.String) | 获取{@link Resource} 资源对象<br> 如果提供路径为绝对路径或路径以file:开头,返回{@link FileResource},否则返回{@link ClassPathResource} |

方法明细

方法名称:cn.hutool.core.io.resource.ResourceUtil.readUtf8Str(java.lang.String)

方法描述

读取Classpath下的资源为字符串,使用UTF-8编码

支持版本及以上

3.1.1

参数描述:

参数名描述
String resourceresource 资源路径,使用相对ClassPath的路径

返回值:

资源内容

参考案例:

  1. final String str = ResourceUtil.readUtf8Str("test.xml");
  2. System.out.println(str);
  3. Assert.assertNotNull(str);
  4. System.out.println("------------------");

源码解析:

  1. 链接:待补充

方法明细

方法名称:cn.hutool.core.io.resource.ResourceUtil.readStr(java.lang.String, java.nio.charset.Charset)

方法描述

读取Classpath下的资源为字符串

支持版本及以上

3.1.1

参数描述:

参数名描述
String resourceresource 可以是绝对路径,也可以是相对路径(相对ClassPath)
Charset charsetcharset 编码

返回值:

资源内容

参考案例:

  1. final String str = ResourceUtil.readStr("test.xml", CharsetUtil.CHARSET_UTF_8);
  2. System.out.println(str);
  3. Assert.assertNotNull(str);
  4. System.out.println("------------------");
  5. final String str1 = ResourceUtil.readStr("C:\\Users\\Administrator\\Desktop\\xuzhu\\aaa.txt", CharsetUtil.CHARSET_UTF_8);
  6. System.out.println(str1);

源码解析:

  1. 链接:待补充

方法明细

方法名称:cn.hutool.core.io.resource.ResourceUtil.readBytes(java.lang.String)

方法描述

读取Classpath下的资源为byte[]

支持版本及以上

4.5.19

参数描述:

参数名描述
String resourceresource 可以是绝对路径,也可以是相对路径(相对ClassPath)

返回值:

资源内容

参考案例:

  1. final byte[] bytes = ResourceUtil.readBytes("test.xml");
  2. System.out.println(new String(bytes,CharsetUtil.CHARSET_UTF_8));

源码解析:

  1. 链接:待补充

方法明细

方法名称:cn.hutool.core.io.resource.ResourceUtil.getStream(java.lang.String)

方法描述

从ClassPath资源中获取{@link InputStream}

支持版本及以上

3.1.2

参数描述:

参数名描述
String resourceresource ClassPath资源

返回值:

{@link InputStream}

参考案例:

  1. final byte[] bytes = IoUtil.readBytes(ResourceUtil.getStream("hutool.jpg"));
  2. Assert.assertEquals(22807, bytes.length);

源码解析:

  1. /**
  2. * 从ClassPath资源中获取{@link InputStream}
  3. *
  4. * @param resource ClassPath资源
  5. * @return {@link InputStream}
  6. * @throws NoResourceException 资源不存在异常
  7. * @since 3.1.2
  8. */
  9. public static InputStream getStream(String resource) throws NoResourceException {
  10. return getResourceObj(resource).getStream();
  11. }

方法明细

方法名称:cn.hutool.core.io.resource.ResourceUtil.getStreamSafe(java.lang.String)

方法描述

从ClassPath资源中获取{@link InputStream},当资源不存在时返回null

支持版本及以上

4.0.3

参数描述:

参数名描述
String resourceresource ClassPath资源

返回值:

{@link InputStream}

参考案例:

  1. //与readBytes 效果一致,只是多加了try catch 的处理,有异常返回Null
  2. final byte[] bytes = IoUtil.readBytes(ResourceUtil.getStreamSafe("hutool.jpg"));
  3. Assert.assertEquals(22807, bytes.length);

源码解析:

  1. /**
  2. * 从ClassPath资源中获取{@link InputStream},当资源不存在时返回null
  3. *
  4. * @param resource ClassPath资源
  5. * @return {@link InputStream}
  6. * @since 4.0.3
  7. */
  8. public static InputStream getStreamSafe(String resource) {
  9. try {
  10. return getResourceObj(resource).getStream();
  11. } catch (NoResourceException e) {
  12. // ignore
  13. }
  14. return null;
  15. }

方法明细

方法名称:cn.hutool.core.io.resource.ResourceUtil.getUtf8Reader(java.lang.String)

方法描述

从ClassPath资源中获取{@link BufferedReader}

支持版本及以上

5.3.6

参数描述:

参数名描述
String resourceresource ClassPath资源

返回值:

{@link InputStream}

参考案例:

  1. final CsvReader reader = CsvUtil.getReader();
  2. final List<Map<String, String>> result = reader.readMapList(
  3. ResourceUtil.getUtf8Reader("test_bean.csv"));
  4. Assert.assertEquals("张三", result.get(0).get("姓名"));
  5. Assert.assertEquals("男", result.get(0).get("gender"));
  6. Assert.assertEquals("无", result.get(0).get("focus"));
  7. Assert.assertEquals("33", result.get(0).get("age"));
  8. Assert.assertEquals("李四", result.get(1).get("姓名"));
  9. Assert.assertEquals("男", result.get(1).get("gender"));
  10. Assert.assertEquals("好对象", result.get(1).get("focus"));
  11. Assert.assertEquals("23", result.get(1).get("age"));
  12. Assert.assertEquals("王妹妹", result.get(2).get("姓名"));
  13. Assert.assertEquals("女", result.get(2).get("gender"));
  14. Assert.assertEquals("特别关注", result.get(2).get("focus"));
  15. Assert.assertEquals("22", result.get(2).get("age"));

源码解析:

  1. 链接:待补充

方法明细

方法名称:cn.hutool.core.io.resource.ResourceUtil.getReader(java.lang.String, java.nio.charset.Charset)

方法描述

从ClassPath资源中获取{@link BufferedReader}

支持版本及以上

3.1.2

参数描述:

参数名描述
String resourceresource ClassPath资源
Charset charsetcharset 编码

返回值:

{@link InputStream}

参考案例:

  1. CsvReader reader = new CsvReader();
  2. CsvData data = reader.read(ResourceUtil.getReader("test.csv", CharsetUtil.CHARSET_UTF_8));
  3. Assert.assertEquals("sss,sss", data.getRow(0).get(0));
  4. Assert.assertEquals("性别", data.getRow(0).get(2));
  5. Assert.assertEquals("关注\"对象\"", data.getRow(0).get(3));

源码解析:

  1. 链接:待补充

方法明细

方法名称:cn.hutool.core.io.resource.ResourceUtil.getResource(java.lang.String)

方法描述

获得资源的URL<br>
路径用/分隔,例如:

  1. config/a/db.config
  2. spring/xml/test.xml

支持版本及以上

参数描述:

参数名描述
String resourceresource 资源(相对Classpath的路径)

返回值:

资源URL

参考案例:

  1. URL url = ResourceUtil.getResource("hutool.jpg");
  2. System.out.println(url);

源码解析:

  1. 链接:待补充

方法明细

方法名称:cn.hutool.core.io.resource.ResourceUtil.getResources(java.lang.String)

方法描述

获取指定路径下的资源列表<br>
路径格式必须为目录格式,用/分隔,例如:

  1. config/a
  2. spring/xml

支持版本及以上

参数描述:

参数名描述
String resourceresource 资源路径

返回值:

资源列表

参考案例:

  1. List<URL> urls = ResourceUtil.getResources("test.xml");
  2. for (URL url : urls) {
  3. System.out.println(url);
  4. }

源码解析:

  1. 链接:待补充

方法明细

方法名称:cn.hutool.core.io.resource.ResourceUtil.getResourceIter(java.lang.String)

方法描述

获取指定路径下的资源Iterator<br>
路径格式必须为目录格式,用/分隔,例如:

  1. config/a
  2. spring/xml

支持版本及以上

4.1.5

参数描述:

参数名描述
String resourceresource 资源路径

返回值:

资源列表

参考案例:

  1. EnumerationIter<URL> urls = ResourceUtil.getResourceIter("test.xml");
  2. for (URL url : urls) {
  3. System.out.println(url);
  4. }

源码解析:

  1. 链接:待补充

方法明细

方法名称:cn.hutool.core.io.resource.ResourceUtil.getResource(java.lang.String, java.lang.Class)

方法描述

获得资源相对路径对应的URL

支持版本及以上

参数描述:

参数名描述
String resourceresource 资源相对路径
java.lang.Class baseClassbaseClass 基准Class,获得的相对路径相对于此Class所在路径,如果为{@code null}则相对ClassPath

返回值:

{@link URL}

参考案例:

  1. URL url = ResourceUtil.getResource("FileUtil.class",FileUtil.class);
  2. System.out.println(url);
  3. System.out.println("----------------");
  4. url = ResourceUtil.getResource("hutool.jpg",null);
  5. System.out.println(url);

源码解析:

  1. 链接:待补充

方法明细

方法名称:cn.hutool.core.io.resource.ResourceUtil.getResourceObj(java.lang.String)

方法描述

获取{@link Resource} 资源对象<br>
如果提供路径为绝对路径或路径以file:开头,返回{@link FileResource},否则返回{@link ClassPathResource}

支持版本及以上

3.2.1

参数描述:

参数名描述
String pathpath 路径,可以是绝对路径,也可以是相对路径(相对ClassPath)

返回值:

{@link Resource} 资源对象

参考案例:

  1. Resource resource = ResourceUtil.getResourceObj("test.xml");
  2. System.out.println(resource.readUtf8Str());

源码解析:

  1. 链接:待补充

今天是持续写作的第 27 / 100 天。
可以关注我,点赞我、评论我、收藏我啦。

相关文章

最新文章

更多

目录