Could not resolve placeholder ‘xxx‘ in value “${xxx}“

问题

今天用idea启动springboot的时候发现某个配置没找到
报错: Injection of autowired dependencies failed; nested exception is java.lang.IllegalArgumentException: Could not resolve placeholder ‘project.url’ in value “${project.url}”

解决过程/思路(不想看思路的直接跳解决方案)

首先,我检查了的所有的配置文件,确定没有问题
然后查看日志,确定是开发环境,需要的配置在文件中都配了
再然后根据日志找到报错的地点
PropertyPlaceholderHelper中的parseStringValue方法,如图
在这里插入图片描述

查找附近代码,发现是因为propVal为null才报错的
在这里插入图片描述
然后从propVal定义的地方开始debugger
发现placeholderResolver.resolvePlaceholder(placeholder);是获取${xxx}中 xxx 的属性,ctrl+u 执行代码
将placeholder替换为其他的属性字符串,发现有些配置的值确实没取到,像是玄学问题:明明所有的配置都写的好好的
但是,所有的玄学问题都是因为不了解才导致的,找不到原因只是因为自己不熟悉
开始思考原因
在这里插入图片描述
众所周知,代码执行的目录是项目编译后的目录,而不是源代码所在的目录,然后就去找编译后的目录中的配置
这个目录springboot的日志其实已经输出来了如图:
在这里插入图片描述
果然,发现编译后的目录中少了配置
在这里插入图片描述
找到原因就好办了,使用maven clear 将生成的文件清空,然后再启动
问题解决!!

解决方案

  1. 检查配置文件中的配置有没有写错
  2. 检查application.yml/bootstrap.yml 配置文件中的active是否配对,或者看日志中的这条日志,然后检查对应的日志文件
    在这里插入图片描述
  3. 如果上述操作检查之后都没问题,检查target目录(或者自己配的class文件输出目录)下的配置文件对不对,如果不对 使用maven clear命令清除这些文件,重新启动
  4. 如果还不行,那就只能在源码中debugger了

结语

所有的玄学问题都是因为我们对它们不够熟悉,所有的bug必然会有一个或多个原因,如果认为它是一个玄学问题,那只能说,我们对这个事物不够熟悉,而不是因为玄学,计算机行业更是如此,让我们的代码中没有玄学

写这篇文章的时候想起了我初入行的时候,不会debug,也不知道如何解决bug,将好多问题归咎于玄学,经常在不知道为什么产生bug的时候使用重启大法,有时有用有时没用,可能就是缺少一些这样的方法论

  • 78
    点赞
  • 61
    收藏
    觉得还不错? 一键收藏
  • 16
    评论
### 回答1: “could not resolve placeholder in value”意思是无法解析占位符的值。这通常是因为在配置文件中使用了占位符,但没有提供相应的值。解决方法是检查配置文件中的占位符是否正确,并确保提供了相应的值。 ### 回答2: 这个错误通常在Spring应用程序中出现,表示应用程序无法解析属性占位符的值。 原因可能是属性文件缺失或无法加载,占位符名称拼写错误或属性文件中没有定义,占位符引用了不存在的环境变量等。 要解决这个问题,需要检查以下几个方面: 1. 确保属性文件存在且被正确加载 首先,确认应用程序加载了正确的属性文件,并确保文件名和路径正确。另外,要确保属性文件中的值包含在占位符中,并且属性文件中的占位符名称与应用程序中的占位符名称相同。可以使用Spring的PropertyPlaceholderConfigurer或PropertySourcesPlaceholderConfigurer类来加载和解析属性文件。 2. 检查占位符名称的正确拼写 确保占位符名称的拼写正确。如果占位符名称与属性文件中定义的名称不匹配,则应用程序将无法解析属性的值。 3. 检查属性文件是否定义了占位符 确保属性文件中定义了占位符,并且占位符名称与应用程序中的占位符名称相同。如果占位符在属性文件中没有定义,应用程序将无法解析属性值。 4. 检查占位符是否引用了不存在的环境变量 如果占位符引用了不存在的环境变量,则应用程序将无法解析属性的值。因此,应该检查占位符引用的环境变量是否存在。 总的来说,要解决这个问题,需要对应用程序的代码、属性文件和环境变量进行细致的检查,找到导致应用程序无法解析占位符值的原因。 ### 回答3: “could not resolve placeholder in value”是Spring框架中常见的错误,通常是由于无法解析属性文件中的占位符导致的。 占位符通常使用${}或者@{}这种格式进行定义,比如在application.properties文件中,我们可能会定义一些占位符来引用一些配置信息,例如: ``` server.port=${my.server.port} ``` 此时,Spring框架会在启动时尝试解析这个占位符,并将${my.server.port}替换为具体的配置值。如果Spring无法解析这个占位符,就会抛出“could not resolve placeholder in value”的异常。 这种情况可能由以下原因导致: 1. 属性文件未正确加载:确保属性文件被正确加载,并且文件路径和文件名正确。 2. 占位符错误:检查占位符的格式和拼写是否正确。比如应该使用${},而不是$(),或者占位符中的名称拼写错误。 3. 未正确定义占位符:在属性文件中未定义对应的占位符,或者定义了一个不存在的占位符。 4. 依赖注入错误:如果占位符需要依赖注入来提供值,那么可能是依赖注入出现问题导致无法解析占位符。 要解决这个问题,开发者可以采取以下方法: 1. 检查属性文件是否正确加载,并且占位符名称、格式和拼写是否正确。 2. 确认占位符的名称和在属性文件中的定义是否一致,如果不一致需要进行修改。 3. 如果依赖注入出现问题,可以检查依赖的注入是否正确,确定是否需要添加相关依赖。 4. 进行日志输出,观察具体的异常信息和堆栈信息,从中查看详细的错误位置和原因。 总之,在遇到“could not resolve placeholder in value”错误时,需要认真排查并解决问题,以确保程序正常运行。
评论 16
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值