https://blog.csdn.net/q646926099/article/details/79082204
使用Ajax跨域請求資源,Nginx作為代理,出現:The 'Access-Control-Allow-Origin' header contains multiple values '*, *', but only one is allowed 錯誤。
服務端允許跨域配置:
#region 設置允許跨域,允許復雜請求 HttpContext.Current.Response.AddHeader("Access-Control-Allow-Origin", "*"); if (HttpContext.Current.Request.HttpMethod == "OPTIONS") { HttpContext.Current.Response.AddHeader("Access-Control-Allow-Methods", "GET,POST,PUT,DELETE,PATCH,OPTIONS"); HttpContext.Current.Response.AddHeader("Access-Control-Allow-Headers", "Content-Type, Accept, Authorization"); //HttpContext.Current.Response.AddHeader("Access-Control-Max-Age", "1728000"); HttpContext.Current.Response.End(); } #endregion ———————————————— 版權聲明:本文為CSDN博主「xiaoqiu_net」的原創文章,遵循 CC 4.0 BY-SA 版權協議,轉載請附上原文出處鏈接及本聲明。 原文鏈接:https://blog.csdn.net/q646926099/article/details/79082204
Nginx的配置:
add_header 'Access-Control-Allow-Origin' '*'; location / { if ($request_method = 'OPTIONS') { add_header Access-Control-Allow-Origin *; add_header Access-Control-Allow-Methods GET,POST,PUT,DELETE,PATCH,OPTIONS; return 200; } proxy_pass http://xx:8002/; #proxy_pass http://localhost:62249/; ———————————————— 版權聲明:本文為CSDN博主「xiaoqiu_net」的原創文章,遵循 CC 4.0 BY-SA 版權協議,轉載請附上原文出處鏈接及本聲明。 原文鏈接:https://blog.csdn.net/q646926099/article/details/79082204
看上面錯誤提示,contains multiple values "*" 意思就是設置了2次跨域,但是只有一個是允許的,移除其中的任意一個就好了。如果服務器設置了允許跨域,使用Nginx代理里面就不需要了(或者就不用使用Nginx了)