angular - Angular 8 + @angular/fire onCall 函数没有 CORS 标头存在错误
问题描述
我在多区域“欧洲西部”中有 Firebase 托管,在“欧洲西部 1”中有 Firebase 功能。onRequest 函数似乎工作正常,但我所有的 onCall 函数都会抛出通用 CORS 错误:
No 'Access-Control-Allow-Origin' header is present on the requested resource.
日志中没有任何用处。
函数示例:
export const ADMIN01AddStaffClaim = functions
.region('europe-west1')
.https.onCall((data, context) => {
if (context.auth) {
if (context.auth.token.owner !== true) {
let error = new HttpsError('permission-denied', 'You must be an app owner to add staff claims');
return { error };
} else {
const email = data.email;
return grantClaim(email, 'staff')
.then(() => {
return { result: 'Added ' + 'staff' + ' claim to ' + email };
})
.catch(err => {
console.log(err);
let error = new HttpsError(
'permission-denied',
'You must be an app owner to add staff claims'
);
return { error };
});
}
} else {
let error = new HttpsError('permission-denied', 'You must be an app owner to add staff claims');
return { error };
}
});
我试过使用 express 的 cors,但从我在文档中读到的内容来看,它不适用于可调用函数。
编辑:对于删除 angular 标签并添加 javascript 的人,我的代码中几乎到处都有打字稿,这是一个来自 angular 的问题,通过正常的浏览器请求工作。
EDIT2:错误被抛出不是因为实际的CORS问题,而是因为我的功能完全是狗屎。
解决方案
我没有从我的函数中正确返回内容,并且默认情况下,CORS 错误似乎是浏览器发出 OPTIONS 请求时的第一个故障点。如果不是因为 CORS 错误,那么当我调用该函数时,这将是一个实际的 500 Internal Server Error。
推荐阅读
- flutter - Flutter 中有无模式对话框吗?
- r - 将两个元素列表合并为一个具有相同元素但每个元素有两个变量的列表
- javascript - 动态更改分配的点击功能
- ios - 崩溃的范围:com.apple.main-thread EXC_BREAKPOINT on ViewController Initialisation
- python - 对 Pandas 中的整个数据框应用数学运算
- sql - 如何根据特定数据的模式对批量表中的数据进行分组?
- c# - 部分类中的自定义属性(列名无效)
- javascript - 如何在 angular.js 中从旧路径重定向用户?
- c - 自定义 Windows 身份验证包的实现 - LsaApUserLogonEx
- gradle - 为什么实施 gradle 依赖项会暴露给消费者