diff --git a/core-java-modules/core-java-io/pom.xml b/core-java-modules/core-java-io/pom.xml
index 1a133d2cbe..84bf3baeed 100644
--- a/core-java-modules/core-java-io/pom.xml
+++ b/core-java-modules/core-java-io/pom.xml
@@ -207,6 +207,21 @@
${maven.compiler.target}
+
+
+
+ org.apache.maven.plugins
+ maven-jar-plugin
+ ${maven-jar-plugin.version}
+
+
+
+ true
+ com.baeldung.resource.MyResourceLoader
+
+
+
+
@@ -274,6 +289,8 @@
1.18
0.1.5
+ 3.1.0
+
\ No newline at end of file
diff --git a/core-java-modules/core-java-io/src/main/java/com/baeldung/resource/MyResourceLoader.java b/core-java-modules/core-java-io/src/main/java/com/baeldung/resource/MyResourceLoader.java
new file mode 100644
index 0000000000..7512b177df
--- /dev/null
+++ b/core-java-modules/core-java-io/src/main/java/com/baeldung/resource/MyResourceLoader.java
@@ -0,0 +1,42 @@
+package com.baeldung.resource;
+
+import java.io.BufferedReader;
+import java.io.FileReader;
+import java.io.IOException;
+import java.io.InputStream;
+import java.io.InputStreamReader;
+import java.util.stream.Collectors;
+
+public class MyResourceLoader {
+
+ private void loadFileWithReader() throws IOException {
+
+ try (FileReader fileReader = new FileReader("src/main/resources/input.txt");
+ BufferedReader reader = new BufferedReader(fileReader)) {
+ String contents = reader.lines()
+ .collect(Collectors.joining(System.lineSeparator()));
+ System.out.println(contents);
+ }
+
+ }
+
+ private void loadFileAsResource() throws IOException {
+
+ try (InputStream inputStream = getClass().getResourceAsStream("/input.txt");
+ BufferedReader reader = new BufferedReader(new InputStreamReader(inputStream))) {
+ String contents = reader.lines()
+ .collect(Collectors.joining(System.lineSeparator()));
+ System.out.println(contents);
+ }
+ }
+
+ public static void main(String[] args) throws IOException {
+
+ MyResourceLoader resourceLoader = new MyResourceLoader();
+
+ resourceLoader.loadFileAsResource();
+ resourceLoader.loadFileWithReader();
+
+ }
+
+}