学无先后,达者为师

网站首页 java综合 正文

Springboot 内部服务调用方式_java

作者:Kings菜鸟   更新时间: 2022-05-16 java综合

Eureka注册的服务之间互相调用

1.请求方

启动类添加注解,扫描Eureka 中的全部服务

@SpringBootApplication
@EnableEurekaClient
@EnableFeignClients
public class LoginServiceApplication {    
    public static void main(String[] args) {
        new SpringApplicationBuilder(LoginServiceApplication.class).web(true).run(args);
    }    
}

pom.xml 添加包 (版本号 根据实际选择)


    org.springframework.cloud
    spring-cloud-starter-feign
    1.4.6.RELEASE

创建接口类

@FeignClient(name="hello-service") //spring service name
public interface FeignVehicle {
    
    @RequestMapping(value="/hello", method = RequestMethod.GET)
    @ResponseBody
    public List hello(@RequestParam Map params);
}

实现类注入此接口类

@Autowired
FeignVehicle feignVehicle;

使用的时候直接按照正常调用方式即可

Map map = new HashMap();
feignVehicle.hello(map);

跨服务调用的时候出现token信息取不到,在发送方添加拦截器

@Configuration
public class FeignConfiguration {
 
    @Bean
    public RequestInterceptor requestInterceptor() {
        return new RequestInterceptor() {
            @Override
            public void apply(RequestTemplate template) { 
                ServletRequestAttributes attributes = (ServletRequestAttributes) RequestContextHolder
                        .getRequestAttributes();
                HttpServletRequest request = attributes.getRequest();  //当前服务token
 
                template.header("Authorization","Bearer " + request.getSession().getId()); //template 接收请求方token
            } 
        };
    }
}

2.接收方

请求 启动类

@SpringBootApplication
@EnableEurekaClient
public class HelloServiceApplication {    
    public static void main(String[] args) {
        new SpringApplicationBuilder(HelloServiceApplication.class).web(true).run(args);
    }    
}

请求Controller

@Controller
@RequestMapping("/hello")
public class HelloController {    
    @RequestMapping(value="/hello",method = RequestMethod.GET)
    @ResponseBody
    public List hello(@RequestParam Map queryParam) {
        return null;  
    }
}

多模块化,服务间调用的坑

问题背景

  • product 服务作为服务端,提供了一个 对外通信Fegin接口 ProductClient,放在了com.imooc.product.client jar包下
  • order 服务作为客户端,直接引用上面的jar,使用 ProductClient ,启动主类后报下图错误:

解决办法

多模块化时,应该在order主类上添加下面圈出来的注解,这样启动后就能扫描这个包。

原文链接:https://blog.csdn.net/purple25/article/details/88691740

栏目分类
最近更新