Spring Cloud 前端调用后端接口方式

在 Spring Cloud 微服务架构中,前端调用后端接口通常不直接通过 Eureka,而是通过以下两种核心方式实现:

一、前端直接调用后端服务(需解决跨域和地址管理问题)

1. AJAX 直接调用

前端通过 HTTP 请求(如 Axios、Fetch)直接访问后端服务的 IP 或域名,例如:

javascript

复制代码
axios.get("http://service-hi:8081/hi/name")

缺点:

  • 需手动管理后端服务地址(IP/端口),难以适应动态扩缩容
  • 需处理跨域问题(CORS),需在后端服务配置 @CrossOrigin 或网关层统一处理
2. 适用场景

仅适合开发环境或服务数量极少的简单项目,生产环境不推荐。

二、通过 API 网关调用(主流方案)

API 网关(如 Spring Cloud Gateway)作为统一入口,是生产环境推荐方式:

1. 工作流程
2.网关核心优势
功能 说明
服务发现集成 自动从 Eureka 获取服务实例列表,无需硬编码地址
动态路由 配置路由规则(如 /api/user/** → user-service)
统一鉴权/限流 在网关层实现身份验证(JWT)、请求限流等
协议转换 支持 REST、WebSocket 等协议转发
负载均衡 集成 Ribbon 实现客户端负载均衡

三、服务间后端调用(与前端无关但需了解)

若前端请求需触发多个微服务调用(如 A 服务调 B 服务),此时后端使用:

1. RestTemplate + Ribbon

java

复制代码
@Bean
@LoadBalanced // 集成Eureka服务发现
public RestTemplate restTemplate() {
  return new RestTemplate();
}
2.OpenFeign 声明式调用

java

复制代码
@FeignClient("service-hi")
public interface ServiceHi {
  @GetMapping("/hi/{name}")
  String sayHi(@PathVariable String name);
}
  • 通过接口伪装 HTTP 客户端,自动负载均衡 (方便简洁)

关键结论

  1. Eureka 的角色
    • 作为服务注册中心管理服务实例地址,不直接处理前端请求
    • 网关/后端服务通过 Eureka 动态解析服务名 → 实际 IP/端口
  2. 生产环境最佳实践
    • 前端 → 网关 → 后端服务(通过 Eureka 发现)
    • 避免前端直连微服务,保证安全性与可维护性
相关推荐
努力奋斗11 分钟前
npm ERR! code CERT_HAS_EXPIRED:解决证书过期问题
前端·npm·node.js
think1236 分钟前
Nacos:微服务世界的"智能管家",让你的代码从此不再迷路
后端·spring cloud
༺๑Tobias๑༻18 分钟前
Linux下Redis常用命令
linux·前端·redis
寅时码1 小时前
我开源了一款 Canvas “瑞士军刀”,十几种“特效与工具”开箱即用
前端·开源·canvas
CF14年老兵1 小时前
🚀 React 面试 20 题精选:基础 + 实战 + 代码解析
前端·react.js·redux
CF14年老兵1 小时前
2025 年每个开发人员都应该知道的 6 个 VS Code AI 工具
前端·后端·trae
think1231 小时前
带你走进Spring Cloud的世界
spring boot·后端·spring cloud
十五_在努力1 小时前
参透 JavaScript —— 彻底理解 new 操作符及手写实现
前端·javascript
拾光拾趣录2 小时前
🔥99%人答不全的安全链!第5问必翻车?💥
前端·面试
IH_LZH2 小时前
kotlin小记(1)
android·java·前端·kotlin