博主在昨天的文章中,提及到项目中选用Eureka作为服务的注册中心,那么今天就应该是开始进行服务的调用, 即认证平台调用数据服务。在之前的文章中我都是很模糊的描述过业务的过程,今天就再叙述一下,也顺便捋一捋自己的业务逻辑。
博主在毕业的时候写有一个微信小程序,小程序所有的接口都写在一个项目中,但是现在因为要开始写PC端, 以及个人项目汇总,那么这一套接口就不能共用了,考虑到后续项目案例汇总比较多,如果按照小程序的路来走, 那么显然有很多重复的工作,于是我需要开始对业务进行分离,也就是拆分,个人的计划如下:
第一步搭建统一的认证平台(可以理解为SSO),然后搭建数据提供服务
第二步搭建注册中心(也就是昨天所描述的Eureka)
第三步搭建其他功能模块的项目,比如文章,题库等等
第四步将小程序接口更换为新的接口
之后的工作就是对PC端和项目的案例的开展了。
今天的工作仍然属于第一步,开始服务间的调用,在SpringCloud的服务调用方案中共有两种:第一种:Ribbon+RestTemplate, 第二种:Feign
博主这里选用Feign,原因如下:Feign是在Ribbon的基础上进行了一次改进,他基于Ribbon,但是使用更加方便, Ribbon的原理可以理解为使用HttpClient 或 RestTemplate 模拟http请求去调用提供的服务,而Feign就封装了调用的步骤, 只需要我们配置相应的注解即可。
服务的提供方:
依赖同昨日项目没有区别,只需要应用注册到Eureka上,然后只需要提供一个Rest接口即可,如下图
服务调用方:
调用方就稍微复杂一下,首先我们需要引入Feign的依赖
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>
然后注解开启Feign,这一步我们需要在启动类上增加注解@EnableFeignClients
@SpringBootApplication
@EnableEurekaClient
@EnableFeignClients
public class SsoApplication {
public static void main(String[] args) {
SpringApplication.run(SsoApplication.class, args);
}
}
调用服务,我们可以写一个接口适配提供的服务。
@FeignClient(name = "baseService")
public interface UserServiceAdapt {
@RequestMapping(method = RequestMethod.POST, value = "/base/getUserInfoByOpenid")
UserVO getUserInfoByOpenid(String token);
}
类的上方要指定提供服务方名称,也就是提供方的配置文件里面的spring.application.name。然后映射中的value要对应到Rest接口路径。
最后一步就是调用了,如下图: