AJAX从一个域请求另一个域会有跨域的问题。那么如何在nginx上实现ajax跨域请求呢?要在nginx上启用跨域请求,需要添加add_header Access-Control*指令。如下所示:
1
2
3
4
5
6
7
8
|
location/{
...
add_header
'Access-Control-Allow-Origin'
'*'
;
add_header
'Access-Control-Allow-Credentials'
'true'
;
add_header
'Access-Control-Allow-Methods'
'GET, POST, OPTIONS'
;
add_header
'Access-Control-Allow-Headers'
'DNT,X-CustomHeader,Keep-Alive,User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type'
;
...
}
|
注释如下:
第一条指令:授权从url的请求,也可以 add_header Access-Control-Allow-Origin http://www.test.com; --授权从www.test.com的请求;
第二条指令:当该标志为真时,响应于该请求是否可以被暴露
第三天指令:指定请求的方法,可以是GET,POST等
重启nginx
#service nginx reload
ajax跨域请求测试
成功时,响应头是如下所示:
HTTP/1.1200OK
Server:nginx
Access-Control-Allow-Origin:other.subdomain.com
本文转自奔跑在路上博客51CTO博客,原文链接http://blog.51cto.com/qiangsh/1764096如需转载请自行联系原作者
qianghong000