FileNotFoundException:xxx(系统找不到指定的路径)

简介: 这次是有个两年前的项目吧,不知道为什么无法启动了。中间迭代了多个版本,现在另一个同事接手了,领导让看一下。因为时间间隔过长,问题处理比较费劲。其中有的是配置问题,比较好解决。中间有个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的源头,尤其是多年的老代码,真的是全靠自己扣,真是太费劲了。

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

相关文章
|
算法 计算机视觉 Python
DSP:数字信号处理技术的魅力与应用
DSP:数字信号处理技术的魅力与应用
成功解决FileNotFoundError: [WinError 2] 系统找不到指定的文件
成功解决FileNotFoundError: [WinError 2] 系统找不到指定的文件。
成功解决FileNotFoundError: [WinError 2] 系统找不到指定的文件
|
缓存
SVN Access to ‘/svn/Test/!svn/me’ forbidden,不能更新解决办法
今天上班,使用公司配置的电脑进行项目的更新。SVN报如下错误,   SVN Access to ‘/svn/Test/!svn/me’ forbidden,不能更新解决办法   很有意思; 开始以为自己的SVN安装有错误; 重装了几次都是同样的异常,经过上网查,才知道,是先前SVN用户缓存的原因。
3427 0
|
7月前
|
机器学习/深度学习 人工智能 并行计算
AI部署架构:A100、H100、A800、H800、H20的差异以及如何选型?开发、测试、生产环境如何进行AI大模型部署架构?
AI部署架构:A100、H100、A800、H800、H20的差异以及如何选型?开发、测试、生产环境如何进行AI大模型部署架构?
AI部署架构:A100、H100、A800、H800、H20的差异以及如何选型?开发、测试、生产环境如何进行AI大模型部署架构?
|
机器学习/深度学习 数据采集 监控
基于YOLOv8的路面缝隙精准识别项目【完整源码数据集+PyQt5界面+完整训练流程+开箱即用!】
这是一套基于YOLOv8的路面裂缝精准识别项目,集成图形化界面(PyQt5)与完整训练流程,支持图片、视频、文件夹及摄像头多种输入方式,开箱即用。系统包含裂缝检测模型、数据集、训练代码和GUI工具,实现从训练到部署的一站式解决方案。核心优势包括高精度检测(mAP超90%)、友好的操作界面、灵活的部署方式,适合高校科研、工程实践及毕业设计。资源包含源码、预训练权重与标注数据,助力快速上手!
麒麟系统mate-indicators进程占用内存过高问题解决
【10月更文挑战第7天】麒麟系统mate-indicators进程占用内存过高问题解决
1348 2
|
网络协议 Windows
【IntelliJ IDEA】idea plugins搜索不出来,如何找到插件的解决方案
【IntelliJ IDEA】idea plugins搜索不出来,如何找到插件的解决方案
11686 0
|
设计模式 API 图形学
Unity精华☀️ 「设计模式」的终极详解!
Unity精华☀️ 「设计模式」的终极详解!
|
Java 容器
JavaMailSender发送邮件(整合SpringBoot、解决空指针异常问题)
一、邮箱开启SMTP服务 以qq邮箱为例 进入邮箱设置页面后选择账户
|
安全 网络安全 API
为什么黑客要攻击你的网站?如何保护网站再被攻击的情况下没有影响!!!!
2023年一季度报告显示,全球超1400万网站遭超10亿次攻击,网络安全风险上升。黑客攻击网站主要动机包括财务收益(如数据窃取、恶意软件传播)、服务中断、企业间谍、黑客行动主义、国家支持的攻击及私人原因。攻击手段涉及损坏的访问控制、开源组件的缺陷、服务器和客户端漏洞、API漏洞及共享主机风险。保护网站的措施包括持续扫描、渗透测试、同步测试与修补、集成WAAP到CI/CD、准备DDoS防御及使用垃圾邮件过滤。