JAVA单体项目之间的调用

文章介绍了如何在单体项目中使用OpenFeign来调用第三方接口。通过添加SpringCloudOpenFeign的依赖,定义FeignClient接口,配置远程调用的URL和名称,可以在项目内部实现对HTTP请求的封装。示例代码展示了调用登录和获取代码的方法,以及如何处理认证Token。
摘要由CSDN通过智能技术生成

简单实现单体项目调用第三方接口

概述:在实际项目中需要调用第三方接口,微服务项目可以通过注册中心+远程调用去实现,那如果是单体项目呢?本章简单介绍下单体项目之间的调用。

1.引入maven依赖。这里使用的是OpenFeign实现的,需要注意的是Spring和OpenFeign的版本兼容的问题。我的Spring版本是2.4.5。 boot2.7.18 可以使用feign3.1.3

<!--feign客户端依赖-->
<dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-openfeign</artifactId>
            <version>3.0.3</version> <!-- 或者根据相应版本选择合适的OpenFeign版本 -->
</dependency>

2.代码实现。

// 调用第三方系统接口URL地址
@FeignClient(name = "${sprints.external.autoDemo.name}",url = "${sprints.external.autoDemo.url}")
public interface TestFeignClient {

    // 调用第三方系统接口
    @PostMapping("/system/only")
    R<?> getCode(@RequestHeader("Authorization") String token, CodeOnlyBo bo);

    // 调用第三方系统登录接口
    @PostMapping("/login")
    R<Map<String, Object>> login(@RequestBody LoginBody loginBody);
}

#    远程调用配置
sprints:
  external:
    autoDemo:
      url: http://127.0.0.1:8080 # url地址
      name: example-service # 名称,单体项目暂时没用到
      username: admin # 登录账号
      password: admin123 # 登录密码
@RestController
@RequestMapping("/t")
public class TestFeginCall {
    @Autowired
    private TestFeignClient testFeignClient;

    @Value("${sprints.external.autoDemo.username}")
    private String username;
    @Value("${sprints.external.autoDemo.password}")
    private String password;

    // 调用方法
    @PostMapping("/getCode")
    public R<?> getCode(@RequestBody CodeOnlyBo bo){
        String token = getToken();
        return testFeignClient.getCode(token, bo);
    }

    // 获取token,这里每次调用方法都重新获取的token,可以进行优化
    private String getToken(){
        LoginBody loginBody = new LoginBody();
        loginBody.setUsername(username);
        loginBody.setPassword(password);
        R<Map<String, Object>> login = testFeignClient.login(loginBody);
        Object token = login.getData().get("token");
        return "Bearer " + token.toString();
    }


}

启动类上方使用@EnableFeignClients注解

结束语:总体来说调用还是基于HTTP请求的,以上代码仅作为参考,实际运用代码还需结合自己的业务情况。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值