Nacos网关解决跨域问题

第一步 Nacos配置

下载Nacos,官网地址为:Naocs下载地址

解压后放入任意目录,打开nacos文件夹中的bin文件,地址栏输入cmd,打开命令行。

Windows启动:输入startup.cmd -m standalone
Linux/Unix/Mac启动:输入sh startup.sh -m standalone
采用以上方式,以单机模式运行nacos。

成功启动后,在项目中创建新的网关模块,在该模块的pom文件中引入以下配置:

 <!-- 网关 -->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-gateway</artifactId>
        </dependency>

        <!-- 服务注册 -->
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
        </dependency>

在项目网关模块配置文件中编写配置:

# 服务端口
server.port=8333

# 服务名
spring.application.name=service-gateway

# nacos服务地址
spring.cloud.nacos.discovery.server-addr=127.0.0.1:8848


#使用服务发现路由
spring.cloud.gateway.discovery.locator.enabled=true

#service-vod模块配置
#设置路由id
spring.cloud.gateway.routes[0].id=service-vod
#设置路由的uri   负载均衡
spring.cloud.gateway.routes[0].uri=lb://service-vod
#设置路由断言,代理servicerId为auth-service的/auth/路径
spring.cloud.gateway.routes[0].predicates= Path=/*/vod/**

#service-order模块配置
#设置路由id
spring.cloud.gateway.routes[1].id=service-order
#设置路由的uri   负载均衡
spring.cloud.gateway.routes[1].uri=lb://service-order
#设置路由断言,代理servicerId为auth-service的/auth/路径
spring.cloud.gateway.routes[1].predicates= Path=/*/order/**

每增加一个新的服务,就需要按照上文中,service-vod模块配置那样放入该配置文件之中,确保能够发现所有的服务。
注意:按照顺序更改序号,不可重复。

第二步 编写跨域配置类

在该类中,通过配置完成跨域。

@Configuration
public class CorsConfig {
    //处理跨域
    @Bean
    public CorsWebFilter corsFilter() {
        CorsConfiguration config = new CorsConfiguration();
        config.addAllowedMethod("*");
        config.addAllowedOrigin("*");
        config.addAllowedHeader("*");
        UrlBasedCorsConfigurationSource source = new UrlBasedCorsConfigurationSource(new PathPatternParser());
        source.registerCorsConfiguration("/**", config);
        return new CorsWebFilter(source);
    }
}

注意:记得将网关配置文件中的端口号和前端的端口号一致。

第三步 服务注册

需要将所有服务都注册到注册中心,每个单独的服务模块中都需要按照如下方式配置

pom文件中引入以下依赖:

<!-- 服务注册 -->
<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>

<!-- 服务调用feign -->
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>

配置文件中,添加注册Nacos服务的配置信息:

# nacos服务地址
spring.cloud.nacos.discovery.server-addr=127.0.0.1:8848

服务的启动类中添加注解,让服务能够被发现

@EnableDiscoveryClient

最后,启动服务,在naocs页面中服务管理模块查看是否完成。

到此已完成所有配置。

注意:

本文为博主的学习笔记,学习地址为:【尚硅谷&腾讯云】Java项目硅谷课堂丨微服务丨在线学习平台

### 如何在 Nacos 中配置解决前端和后端之间的 CORS 问题 #### 配置策略 为了使 Nacos 支持请求,在 Nacos 的配置文件 `application.properties` 或者 `bootstrap.yml` 文件中添加如下配置: ```yaml server: servlet: context-path: / management: endpoints: web: exposure: include: "*" spring: cloud: nacos: discovery: server-addr: localhost:8848 ``` 上述配置并不是直接用于解决CORS问题,而是确保Nacos服务正常启动并注册到服务中心[^1]。 针对具体的微服务应用,如果使用的是 Spring Cloud Gateway,则可以在其配置文件中加入全局设置。这使得通过该网关的所有API都能响应来自指定源的请求: ```yaml spring: cloud: gateway: globalcors: add-to-simple-url-handler-mapping: true corsConfigurations: '[/**]': allowedOrigins: "http://localhost:3000" # 替换成实际前端地址 allowedMethods: - PUT - DELETE - OPTIONS allowedHeaders: "*" exposedHeaders: "*" allowCredentials: true ``` 这段 YAML 片段展示了如何利用Spring Cloud Gateway特性来统一管理整个系统的行为[^3]。 另外一种方式是在具体控制器上加注解以快速启用单个接口级别的支持: ```java @RestController @RequestMapping("/api") public class MyController { @GetMapping("/data") @CrossOrigin(origins = "http://localhost:3000") // 只允许特定来源访问此接口 public ResponseEntity<String> getData() { return new ResponseEntity<>("Data from backend", HttpStatus.OK); } } ``` 这种方式适合于小型项目或是只需要部分接口开放给外部调用的情况[^2]。 综上所述,对于大型分布式系统而言推荐采用Gateway层面做集中化控制;而对于简单场景则可以直接在业务逻辑层面上进行局部调整即可满足需求。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值