指定 Access-Control-Allow-Origin 为 ‘*' ,即为最简单暴力的允许所有访问跨域有些场景下需要使用 Cookie,这时 Nginx 需要加一句 add_header Access-Control-Allow-Credentials 'true';,但此时会发现浏览器报错,说该参数为 true 时,allow origin 不能设置为 ‘*‘,如果手动指定了多个域名,那同样会被浏览器提示错误,说 allow origin 不能设置多个,这些是协议层面的限制在 Nginx 中可以使用 map 得到一个自定义变量,简单的使用可以参考官方文档,在上面提到的场景中,可以对请求中的 origin 做一个过滤处理,把符合要求的请求域名放到一个变量中,在设置 allow origin 时使用该变量就能实现一个动态的、多个的允许跨域域名一个示例配置如下:$http_origin 是 Nginx 的内部变量,用于获取请求头中的 origin$allow_origin 是可以自定义的变量名

如何利用map实现Nginx允许多个域名跨域

如何利用map实现Nginx允许多个域名跨域