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

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

❤️作者主页:小虚竹

❤️作者简介:大家好,我是小虚竹。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> 路径用/分隔,例如:
config/a/db.config spring/xml/test.xml

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

config/a spring/xml

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

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的路径

返回值:

资源内容

参考案例:

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

源码解析:

链接:待补充

方法明细

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

方法描述

读取Classpath下的资源为字符串

支持版本及以上

3.1.1

参数描述:

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

返回值:

资源内容

参考案例:

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

源码解析:

链接:待补充

方法明细

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

方法描述

读取Classpath下的资源为byte[]

支持版本及以上

4.5.19

参数描述:

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

返回值:

资源内容

参考案例:

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

源码解析:

链接:待补充

方法明细

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

方法描述

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

支持版本及以上

3.1.2

参数描述:

参数名描述
String resourceresource ClassPath资源

返回值:

{@link InputStream}

参考案例:

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

源码解析:

/**
	 * 从ClassPath资源中获取{@link InputStream}
	 * 
	 * @param resource ClassPath资源
	 * @return {@link InputStream}
	 * @throws NoResourceException 资源不存在异常
	 * @since 3.1.2
	 */
	public static InputStream getStream(String resource) throws NoResourceException {
		return getResourceObj(resource).getStream();
	}

方法明细

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

方法描述

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

支持版本及以上

4.0.3

参数描述:

参数名描述
String resourceresource ClassPath资源

返回值:

{@link InputStream}

参考案例:

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

源码解析:

/**
	 * 从ClassPath资源中获取{@link InputStream},当资源不存在时返回null
	 * 
	 * @param resource ClassPath资源
	 * @return {@link InputStream}
	 * @since 4.0.3
	 */
	public static InputStream getStreamSafe(String resource) {
		try {
			return getResourceObj(resource).getStream();
		} catch (NoResourceException e) {
			// ignore
		}
		return null;
	}

方法明细

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

方法描述

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

支持版本及以上

5.3.6

参数描述:

参数名描述
String resourceresource ClassPath资源

返回值:

{@link InputStream}

参考案例:

final CsvReader reader = CsvUtil.getReader();
		final List<Map<String, String>> result = reader.readMapList(
				ResourceUtil.getUtf8Reader("test_bean.csv"));

		Assert.assertEquals("张三", result.get(0).get("姓名"));
		Assert.assertEquals("男", result.get(0).get("gender"));
		Assert.assertEquals("无", result.get(0).get("focus"));
		Assert.assertEquals("33", result.get(0).get("age"));

		Assert.assertEquals("李四", result.get(1).get("姓名"));
		Assert.assertEquals("男", result.get(1).get("gender"));
		Assert.assertEquals("好对象", result.get(1).get("focus"));
		Assert.assertEquals("23", result.get(1).get("age"));

		Assert.assertEquals("王妹妹", result.get(2).get("姓名"));
		Assert.assertEquals("女", result.get(2).get("gender"));
		Assert.assertEquals("特别关注", result.get(2).get("focus"));
		Assert.assertEquals("22", result.get(2).get("age"));

源码解析:

链接:待补充

方法明细

方法名称: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}

参考案例:

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

源码解析:

链接:待补充

方法明细

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

方法描述

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

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

支持版本及以上

参数描述:

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

返回值:

资源URL

参考案例:

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

源码解析:

链接:待补充

方法明细

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

方法描述

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

config/a
 spring/xml

支持版本及以上

参数描述:

参数名描述
String resourceresource 资源路径

返回值:

资源列表

参考案例:

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

源码解析:

链接:待补充

方法明细

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

方法描述

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

config/a
 spring/xml

支持版本及以上

4.1.5

参数描述:

参数名描述
String resourceresource 资源路径

返回值:

资源列表

参考案例:

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

源码解析:

链接:待补充

方法明细

方法名称: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}

参考案例:

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

源码解析:

链接:待补充

方法明细

方法名称: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} 资源对象

参考案例:

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

源码解析:

链接:待补充

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

相关文章

微信公众号

最新文章

更多

目录