实战FileNotFoundException

前言

这次是有个两年前的项目吧,不知道为什么无法启动了。中间迭代了多个版本,现在另一个同事接手了,领导让看一下。因为时间间隔过长,问题处理比较费劲。其中有的是配置问题,比较好解决。

中间有个FileNotFoundException的问题困扰了很长时间,最后找了个简单法子解决,希望给有碰到的网友提供些方法和灵感。报错如下:

请在此添加图片描述

背景

我用的idea而领导用的eclipse,这个无论是哪个用tomcat是没有这个错误的。而使用maven启动就不行,原因大致如下:

1.当我们使用Maven来运行Spring Boot Application时,它默认会从项目的根目录下的 /src/main/resources 文件夹读取资源文件。

2.而当我们使用Tomcat来运行Spring Boot Application时,它会从编译过后的 /target/classes 文件夹读取资源文件。

3.最后还发现了在pom文件中有相关创建etc文件夹下的代码,关键代码和截图:

<plugin>
   <groupId>org.apache.maven.plugins</groupId>
   <artifactId>maven-war-plugin</artifactId>
   <version>2.1.1</version>
   <configuration>
      <!--将类文件打成war包 -->
      <failOnMissingWebXml>false</failOnMissingWebXml>
      <!--将资源文件打到classes目录下 -->
      <webResources>
         <resource>
            <directory>data/poem</directory>
            <targetPath>WEB-INF/data/poem</targetPath>
            <filtering>true</filtering>
         </resource>
         <resource>
            <directory>etc</directory>
            <targetPath>WEB-INF/etc</targetPath>
            <filtering>true</filtering>
         </resource>
      </webResources>
   </configuration>
</plugin>

请在此添加图片描述

问题流程:可以正常启动,中间报错也可以,但是访问接口就会报错,然后自动停止(maven启动)。如下图:

请在此添加图片描述

请在此添加图片描述

解决方法

1.直接在下面建立一个名为etc文件夹的

请在此添加图片描述

2.在IDEA中,你可以通过以下步骤设置Maven的工作目录:

  1. 在IDEA的右侧边栏中打开 "Maven Projects" 工具窗口。
  2. 找到你想运行的Maven项目,右键点击并选择 "Run Maven Build..."。
  3. 在弹出的对话框中,找到 "Working directory" 区域,填入你想设置的目录路径,比如

请在此添加图片描述

  1. 之后每次运行该Maven项目时,都会使用你设置的工作目录。这样应该就可以解决你的问题了。

提醒一下,使用绝对路径可能会导致你的项目在其他环境中无法正常运行。如果可能,建议你使用相对路径或类路径来引用资源文件。

思路:我们在报错日志中可以明显看到这个是去寻找的绝对路径,所以我们如果只是想本地测试的话,直接使用上面的办法指定目录即可。

在代码中查到引用了一个包,包中的业务逻辑是查询项目下etc文件。因为我使用的时候是21年,所以我强烈怀疑是有人后期有改动这个配置的代码地址,并且我回滚后依旧无法正常启动。

请在此添加图片描述

错误示例

这些下面是我在网上百度是碰到的一些解决方法,没有顶用的,供大家参考下。

1.修改配置文件的路径:

data-cloud-service-client.properties

文件移动到你的源代码目录,如src/main/resources,然后在代码中使用

classpath:data-cloud-service-client.properties

请在此添加图片描述

2.使用Spring的@PropertySource注解: 如果你使用Spring,可以用@PropertySource注解来指定配置文件的位置。它可以支持文件路径和类路径,比如:

@Configuration
@PropertySource("file:E:/Project/unios/unios-skill-bspt/unios-skill-bspt-controller/etc/data-cloud-service-client.properties")
public class Application {

   public static void main(String[] args) {

      SpringApplication.run(Application.class, args);

   }

}

请在此添加图片描述

3.在Maven pom.xml文件中添加资源(有可能可以): 可以在pom.xml文件中指定额外的资源路径。下面是一个例子:

<resources>
			<resource>
				<directory>unios-skill-bspt/${project.basedir}/etc</directory>
				<includes>
					<include>data-cloud-service-client.properties</include>
				</includes>
			</resource>
		</resources>

请在此添加图片描述

说实话这个bug解决倒是不难,难点在于找到bug的源头,尤其是多年的老代码,真的是全靠自己扣,真是太费劲了。

今天就到这里吧,感觉有用的小伙伴可以点个赞,你的支持就是我更新的最大动力!

#java实战#
技术 文章被收录于专栏

不秃头

全部评论

相关推荐

4 收藏 评论
分享
牛客网
牛客企业服务