Angular中出现“No'Access-Control-Allow-Origin'headerispresent”错误(不是一直出现)
创始人
2024-10-31 01:00:37
0
  1. 确认后端API是否开启了CORS。如果没有开启,可以在代码中添加以下代码:

app.use((req, res, next) => { res.header('Access-Control-Allow-Origin', '*'); res.header('Access-Control-Allow-Headers', 'Content-Type'); next(); });

  1. 如果后端API已经开启了CORS,可以尝试在请求头中添加以下内容:

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

const httpOptions = { headers: new HttpHeaders({ 'Content-Type': 'application/json', 'Access-Control-Allow-Origin': '*' }) };

this.http.post(url, body, httpOptions).subscribe(data => { // 请求成功处理 });

  1. 如果以上两种方法都没有解决问题,可以尝试使用代理。在angular.json文件中,在"architect">"serve">"options"中添加以下代码:

"proxyConfig": "proxy.conf.json"

并在项目根目录下创建proxy.conf.json文件,添加以下代码:

{ "/api/*": { "target": "http://localhost:3000", "secure": false, "changeOrigin": true } }

其中,target为后端API的地址。

  1. 如果以上三种方法都没有解决问题,可以尝试使用JSONP(仅适用于GET请求)。在angular.json文件中,在"architect">"build">"options"中添加以下代码:

"json": true

并在代码中添加以下代码:

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

this.http.jsonp(url, 'callback').subscribe(data => { // 请求成功处理 });

其中,callback为后端返回的函数名称。需要在后端API中进行设置。

相关内容

热门资讯

透视技巧!wepoker数据分... 透视技巧!wepoker数据分析(透视)wepoker可以透视码(一直一直都是有透视)-哔哩哔哩1、...
透视方法!wepoker私人局... 透视方法!wepoker私人局俱乐部(透视)wepoker私人局有透视吗(本来一直都是有辅助器)-哔...
透视技巧!wepoker祈福有... 透视技巧!wepoker祈福有用吗(透视)wejoker免费脚本(果然一直都是有脚本)-哔哩哔哩1、...
透视app!wpk辅助购买(透... 透视app!wpk辅助购买(透视)wpk俱乐部是真的吗(都是存在有透视)-哔哩哔哩1、每一步都需要思...
透视攻略!德普之星透视辅助软件... 透视攻略!德普之星透视辅助软件(透视)德普之星透视辅助插件(竟然存在有辅助器)-哔哩哔哩一、德普之星...
透视app!hhpoker哪个... 透视app!hhpoker哪个俱乐部靠谱(透视)hhpoker有没有作必弊辅助(竟然是真的有透视)-...
透视技巧!wepoker可以透... 透视技巧!wepoker可以透视码(透视)wepoker辅助器安装包定制(一直一直都是有挂)-哔哩哔...
透视软件!wepoker免费透... 透视软件!wepoker免费透视脚本(透视)wepoker透视有用吗(总是有脚本)-哔哩哔哩小薇(辅...
透视攻略!wepokerplu... 透视攻略!wepokerplus脚本(透视)wepoker透视方法(一贯是真的有挂)-哔哩哔哩1、w...
透视技巧!hhpoker买挂(... 透视技巧!hhpoker买挂(透视)hhpoker到底可以作必弊码(原来存在有挂)-哔哩哔哩1)hh...