我试图根据产品或非产品环境动态添加allowedOrigin。尝试了几种方法,但是这些都不起作用。对于Prod,我们只允许3个域,但是对于较低环境,我们希望允许任何源。有人可以帮忙吗。
"variables": {
"corsAllowedUrls": [
"https://www.example.com",
"https://app2.example.com",
"https://m2.example.com"
]
}
.......
"type": "Microsoft.Web/sites",
"siteConfig": {
"cors": {
"allowedOrigins": [
"[if(equals(parameters('azureEnvironment'),'prod'), variables('corsAllowedUrls'), '*')]"
]
},
第二个选项,该选项适用于产品,但对于其他环境,它添加了三行,它们随机起作用而随机不起作用。
"siteConfig": {
"cors": {
"allowedOrigins": [
"[if(equals(parameters('azureEnvironment'),'prod'), 'https://ww2.example.com', '*')]",
"[if(equals(parameters('azureEnvironment'),'prod'), 'https://app2.example.com', '')]",
"[if(equals(parameters('azureEnvironment'),'prod'), 'https://m2.example.com', '')]"
]
}
我也尝试过发送逗号分隔的字符串并使用split函数。 理想的情况是拥有通配符,但似乎Azure中不支持这些通配符。
感谢您的帮助。
答案 0 :(得分:3)
请尝试:
"variables": {
"corsAllowedProdUrls": [
"https://www.example.com",
"https://app2.example.com",
"https://m2.example.com"
],
"corsAllowedDevUrls": [
"*"
]
}
.......
"type": "Microsoft.Web/sites",
"siteConfig": {
"cors": {
"allowedOrigins": "[if(equals(parameters('azureEnvironment'),'prod'), variables('corsAllowedProdUrls'), variables('corsAllowedDevUrls'))]"
},