spring cloud-Feign使用中遇到的问题总结

问题一:

在前面的示例中,我们讲过

@RequestMapping(value = "/user/{id}", method = RequestMethod.GET)
@GetMapping("/user/{id}")
这两个注解的效果是等价的,但是在Feign使用中,只能用上面的那种方式,不能直接用@GetMapping,下面我们将前面的那个示例中,改成@GetMapping注解看下效果,我们发现,修改注解后重新启动服务的时候,抛了如下异常:

Caused by: java.lang.IllegalStateException: Method findById not annotated with HTTP method type (ex. GET, POST)
异常的意思是,我们没有指定HTTP的方法

问题二:

在前面的示例中,我们暴漏Restful服务的方式如下:

@GetMapping("/template/{id}")
	public User findById(@PathVariable Long id) {
		return client.findById(id);
	}
这里,findById方法的参数中,我们直接使用了
@PathVariable Long id
下面我们将Feign的方式也改成这种

@RequestMapping(value = "/user/{id}", method = RequestMethod.GET)
	User findById(@PathVariable Long id);
然后启动服务,我们发现,又抛异常了,异常信息如下:

Caused by: java.lang.IllegalStateException: PathVariable annotation was empty on param 0.
大概的意思是PathVariable注解的第一个参数不能为空,我们改成如下的方式:

@RequestMapping(value = "/user/{id}", method = RequestMethod.GET)
	User findById(@PathVariable("id") Long id);

再启动,发现一切都ok了。

问题三:多参数问题

@RequestMapping(value="/user/name", method=RequestMethod.GET)
	User findByUsername(final String userName,  final String address);
启动服务的时候,会报如下异常:

Caused by: java.lang.IllegalStateException: Method has too many Body parameters: public abstract com.chhliu.springboot.restful.vo.User com.chhliu.springboot.restful.feignclient.UserFeignClient.findByUsername(java.lang.String,java.lang.String)

异常原因:当使用Feign时,如果发送的是get请求,那么需要在请求参数前加上@RequestParam注解修饰,Controller里面可以不加该注解修饰。

上面问题的解决方案如下:

@RequestMapping(value="/user/name", method=RequestMethod.GET)
	User findByUsername(@RequestParam("userName") final String userName, @RequestParam("address") final String address);

问题四:Request method 'POST' not supported

错误代码示例:

@RequestMapping(value="/user/name", method=RequestMethod.GET)
	User findByUsername(final String userName, @RequestParam("address") final String address);

注意:上面的userName参数没有用@RequestParam注解修饰,然后发送请求,会发现被调用的服务一直报Request method 'POST' not supported,我们明明使用的是GET方法,为什么被调用服务认为是POST方法了,原因是当userName没有被@RequestParam注解修饰时,会自动被当做request body来处理。只要有body,就会被feign认为是post请求,所以整个服务是被当作带有request parameter和body的post请求发送出去的。



Spring Cloud Starter Feign Ribbon Bootstrap AngularJS 是一个基于 Spring Cloud 的微服务架构项目,它整合了 Feign、Ribbon 和 AngularJS。以下是该项目的一些主要特点和组成部分: 1. **Feign**: Feign 是一个声明式的 Web 服务客户端,使得调用 HTTP 接口变得简单。通过定义一个接口并使用注解来描述请求,Feign 会自动生成代码来实现这些请求。 2. **Ribbon**: Ribbon 是 Netflix 发布的负载均衡器,它可以与 Feign 结合使用,实现对多个服务实例的负载均衡。 3. **Bootstrap**:Spring Cloud 中,Bootstrap 通常用于加载配置信息。在这个项目中,Bootstrap 可能用于加载一些全局配置或初始化一些资源。 4. **AngularJS**: AngularJS 是一个前端 JavaScript 框架,用于构建动态的单页面应用(SPA)。在这个项目中,AngularJS 可能用于开发前端界面,与后端的 Spring Cloud 服务进行交互。 5. **Spring Cloud Starter**: Spring Cloud Starter 是一组自动化配置的集合,简化了 Spring Cloud 应用程序的开发。在这个项目中,Spring Cloud Starter 提供了 Feign 和 Ribbon 的自动配置。 6. **项目结构**: 这个项目的结构可能包括以下几个部分: - `src/main/java`: 存放 Java 源代码文件。 - `src/main/resources`: 存放配置文件,如 application.yml 或 application.properties。 - `src/main/webapp`: 存放静态资源文件,如 HTML、CSS 和 JavaScript 文件。 - `src/test/java`: 存放单元测试代码。 - `pom.xml`: Maven 项目的配置文件,用于管理项目依赖和构建过程。 7. **依赖管理**: 在 pom.xml 文件中,可能会包含以下依赖: - Spring Boot Starter Web - Spring Cloud Starter OpenFeign - Spring Cloud Starter Netflix Ribbon - AngularJS (如果使用 Maven 进行前端依赖管理) 8. **示例代码**: 以下是一个简化的示例代码,展示了如何使用 Feign 和 Ribbon 进行服务调用: ```java @FeignClient(name = "service-name", configuration = FeignConfig.class) public interface ServiceClient { @RequestMapping(value = "/api/resource", method = RequestMethod.GET) String getResource(); } @Configuration public class FeignConfig { @Bean public IRule ribbonRule() { return new RoundRobinRule(); // 使用轮询策略进行负载均衡 } } @RestController public class MyController { @Autowired private ServiceClient serviceClient; @GetMapping("/my-endpoint") public String myEndpoint() { return serviceClient.getResource(); } } ``` 9. **注意事项**:使用 Spring Cloud Starter Feign Ribbon Bootstrap AngularJS 时,需要注意以下几点: - 确保所有依赖的版本兼容。 - 正确配置 Feign 和 Ribbon 的相关属性。 - 如果使用 AngularJS,确保前端代码与后端 API 正确对接。 - 处理可能出现的异常和错误情况。
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值