Angular前端和JavaSpringBoot后端中被CORS策略阻止的请求?
创始人
2024-10-29 02:00:38
0

1.在Spring Boot后端的控制器类中添加@CrossOrigin注解。

如下所示:

@RestController
@CrossOrigin(origins = "http://localhost:4200")
public class MyController {
   ...
}

其中,origins参数指定了允许的源,可以是域名或IP地址。此参数是可选的,也可以设置为通配符*,表示允许来自任何源的请求。

2.在Angular前端的请求配置中添加withCredentials: true选项。

如下所示:

import { HttpClient } from '@angular/common/http';

@Injectable()
export class MyService {
    private url = 'http://localhost:8080/some-endpoint';

    constructor(private http: HttpClient) {}

    getData() {
        const options = { withCredentials: true };
        return this.http.get(this.url, options);
    }
}

这里withCredentials选项指定了是否在请求中发送凭证(如cookie)。

需要注意的是,如果在Angular前端中使用了HttpInterceptor拦截器,则可能需要在拦截器中手动添加withCredentials选项,如下所示:

import { Injectable } from '@angular/core';
import { HttpInterceptor, HttpHandler, HttpRequest } from '@angular/common/http';

@Injectable()
export class MyInterceptor implements HttpInterceptor {
    intercept(req: HttpRequest, next: HttpHandler) {
        const authReq = req.clone({ withCredentials: true });
        return next.handle(authReq);
    }
}

这里拦截器使用clone()方法创建了一个新的请求,并将withCredentials选项添加到了该请求中。需要将拦截器添加到providers数组中,以便在应用程序中使用。

相关内容

热门资讯

相较于以往!微信边锋辅助下载,... 相较于以往!微信边锋辅助下载,对战互娱辅助系统-总是真的是有辅助方法(哔哩哔哩)1、这是跨平台的微信...
2026版复盘!决战卡五星辅助... 2026版复盘!决战卡五星辅助看牌器,哈糖大菠萝辅助-本来存在有辅助工具(哔哩哔哩)1、下载好决战卡...
于此同时!新道游辅助透视下载,... 于此同时!新道游辅助透视下载,众亿辅助-果然存在有辅助软件(哔哩哔哩)1、新道游辅助透视下载公共底牌...
透视神器!微信小程序辅助有哪些... 透视神器!微信小程序辅助有哪些,嘟咪互动修改器-确实是真的有辅助教程(哔哩哔哩)微信小程序辅助有哪些...
事发当天!新畅游互娱辅助,八闽... 事发当天!新畅游互娱辅助,八闽掌上辅助软件-一贯存在有辅助教程(哔哩哔哩)1、上手简单,内置详细流程...
透视规律!福建十三兵修改器,微... 透视规律!福建十三兵修改器,微友三代辅助-原来是真的有辅助技巧(哔哩哔哩)福建十三兵修改器辅助器是一...
刚刚!微信边锋辅助挂件,掌中乐... 刚刚!微信边锋辅助挂件,掌中乐游戏修改器-一直确实有辅助挂(哔哩哔哩)1、掌中乐游戏修改器辅助器安装...
透视实锤!科乐填大坑作必弊码,... 透视实锤!科乐填大坑作必弊码,福建天天开心王国辅助-切实存在有辅助技巧(哔哩哔哩)1、福建天天开心王...
规律辅助挂!兴动互娱游戏辅助器... 规律辅助挂!兴动互娱游戏辅助器,杭州边锋辅助软件-一贯真的有辅助神器(哔哩哔哩)1、操作简单,无需兴...
近期!边锋老友荣成辅助,牛总管... 近期!边锋老友荣成辅助,牛总管辅助神器-其实确实有辅助方法(哔哩哔哩)1、边锋老友荣成辅助免费脚本咨...