Feign Client with Spring Boot: RequestParam.value() was empty on parameter 0

本文探讨FeignClient中@RequestParam注解value属性为空引发的问题,分析Feign与SpringMVC在参数名发现机制上的差异,解释为何Feign需显式指定参数名。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

出现这个问题大多是Feign Client关于@RequestParam注解引起的问题。

错误详情:
在这里插入图片描述
意思是说@RequestParam注解的value属性不能为空,这是为什么呢?
先看看FeignClient接口的方法:
在这里插入图片描述
这样启动的话会报错的,就是上述的错误。我们知道在springMvc中,controller方法使用上@RequestParam注解可以不指定value,只要传递过来的参数名称和你方法参数名称一致就可以接收到值,否则为null。为什么到了Feign中就不行了呢,需要指定value启动才不会报错。
在这里插入图片描述
其实区别很简单,controller是类,而Feign是接口。Spring MVC和Spring cloud feign都使用相同的ParameterNameDiscoverer-名称DefaultParameterNameDiscoverer来查找参数名称。它尝试通过以下步骤查找参数名称。
1.首先,它使用StandardReflectionParameterNameDiscoverer。它试图通过反射找到变量名。仅当使用编译您的类时才可能使用到-parameters参数。接口如果没有显式指定-parameters则会忽略方法中的参数。

2.其次,如果失败,则使LocalVariableTableParameterNameDiscoverer。它尝试使用ASM库从类文件中的调试信息中找到变量名。

3.Spring MVC和Feign之间的区别出现在这里。Feign 在Java接口的方法上使用了上述注释(如@RequestParam)。但是,当使用Spring MVC时,我们将它们用于Java类的方法。不幸的是,javac编译器从java接口的类文件中省略了参数名的调试信息。这就是为什么feign找不到不带参数的名称-parameter。
也就是说,如果使用-parameters编译代码,Spring MVC和Feign都将成功获取参数名称。但是,如果不进行-parameters编译,则只有Spring MVC会成功。

Error starting ApplicationContext. To display the condition evaluation report re-run your application with 'debug' enabled. 2025-08-19 17:05:35.745 ERROR 22908 --- [ restartedMain] o.s.boot.SpringApplication : Application run failed org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'testController': Unsatisfied dependency expressed through field 'businessFeign': Error creating bean with name 'com.lx.train.batch.feign.BusinessFeign': Instantiation of supplied bean failed at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.resolveFieldValue(AutowiredAnnotationBeanPostProcessor.java:788) at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.inject(AutowiredAnnotationBeanPostProcessor.java:768) at org.springframework.beans.factory.annotation.InjectionMetadata.inject(InjectionMetadata.java:146) at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor.postProcessProperties(AutowiredAnnotationBeanPostProcessor.java:509) at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.populateBean(AbstractAutowireCapableBeanFactory.java:1435) at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:600) at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:523) at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:336) at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:288) at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:334) at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:199) at org.springframework.beans.factory.support.DefaultListableBeanFactory.instantiateSingleton(DefaultListableBeanFactory.java:1122) at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingleton(DefaultListableBeanFactory.java:1093) at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:1030) at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:987) at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:627) at org.springframework.boot.web.servlet.context.ServletWebServerApplicationContext.refresh(ServletWebServerApplicationContext.java:146) at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:752) at org.springframework.boot.SpringApplication.refreshContext(SpringApplication.java:439) at org.springframework.boot.SpringApplication.run(SpringApplication.java:318) at com.lx.train.batch.config.BatchApplication.main(BatchApplication.java:22) at java.base/jdk.internal.reflect.DirectMethodHandleAccessor.invoke(DirectMethodHandleAccessor.java:103) at java.base/java.lang.reflect.Method.invoke(Method.java:580) at org.springframework.boot.devtools.restart.RestartLauncher.run(RestartLauncher.java:50) Caused by: org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'com.lx.train.batch.feign.BusinessFeign': Instantiation of supplied bean failed at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.obtainFromSupplier(AbstractAutowireCapableBeanFactory.java:1239) at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBeanInstance(AbstractAutowireCapableBeanFactory.java:1176) at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:563) at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:523) at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:336) at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:288) at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:334) at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:199) at org.springframework.beans.factory.config.DependencyDescriptor.resolveCandidate(DependencyDescriptor.java:254) at org.springframework.beans.factory.support.DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:1626) at org.springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency(DefaultListableBeanFactory.java:1514) at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.resolveFieldValue(AutowiredAnnotationBeanPostProcessor.java:785) ... 23 common frames omitted Caused by: java.lang.IllegalStateException: Method BusinessFeign#genDaily(Date) not annotated with HTTP method type (ex. GET, POST) Warnings: - Class BusinessFeign has annotations [FeignClient] that are not used by contract Default - Method genDaily has an annotation GetMapping that is not used by contract Default at feign.Util.checkState(Util.java:118) at feign.Contract$BaseContract.parseAndValidateMetadata(Contract.java:117) at feign.Contract$BaseContract.parseAndValidateMetadata(Contract.java:71) at feign.DeclarativeContract.parseAndValidateMetadata(DeclarativeContract.java:40) at feign.ReflectiveFeign$ParseHandlersByName.apply(ReflectiveFeign.java:140) at feign.ReflectiveFeign.newInstance(ReflectiveFeign.java:59) at feign.ReflectiveFeign.newInstance(ReflectiveFeign.java:51) at feign.Feign$Builder.target(Feign.java:202)
最新发布
08-20
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值