Nginx入门及如何反向代理 跨域解决生产环境跨域问题

拒绝访问 | www.vuln.cn | 百度云加速
请打开cookies.
此网站 (www.vuln.cn) 的管理员禁止了您的访问。原因是您的访问包含了非浏览器特征(426dd94cb1b043fb-ua98).
重新安装浏览器,或使用别的浏览器没有更多推荐了,
加入CSDN,享受更精准的内容推荐,与500万程序员共同成长!Nginx 实现AJAX跨域请求AJAX从一个域请求另一个域会有跨域的问题。那么如何在nginx上实现ajax跨域请求呢?要在nginx上启用跨域请求,需要添加add_header
Access-Control*指令。如下所示:
location /{
add_header 'Access-Control-Allow-Origin' '';
add_header 'Access-Control-Allow-Credentials' 'true';
add_header 'Access-Control-Allow-Methods' 'GET';
the rest of your configuration here
注释如下:
第一条指令:授权从other.subdomain.com的请求
第二条指令:当该标志为真时,响应于该请求是否可以被暴露
第三天指令:指定请求的方法,可以是GET,POST等
如果需要允许来自任何域的访问,可以这样配置:
Access-Control-Allow-Origin: *
service nginx reload
ajax跨域请求测试成功时,响应头是如下所示:
HTTP/1.1 200 OK
Server: nginx
Access-Control-Allow-Origin: other.subdomain.com
用Nginx和Apache的反向代理解决Ajax的跨域问题
&&&&&&&& 傲游主站上有一个很吸引人的功能,就是下载次数计数,如下图所示。这个功能就是利用了上述技术实现的。
&从下图的Firebug中可以看到,该页面通过Ajax反复请求一个名为/api/counter的路径以径获取最新的下载数量。
而这个输出路径实际上在服务器上是不存在的,这个路径只是另外一台服务器某个路径而已,这就是使用了Nginx的反向代理功能实现的。&&&&&
1、Nginx&&&&&&&& 回到计数器的这个例子,Nginx的配置片段如下所示:
location /api/counter {
&&rewrite (.*) /
&&&proxy_pass
&&proxy_set_header Host "hfahe.maxthon.com";
那么访问http://www.maxthon.cn/api/counter这个地址,输出和直接访问http://hfahe.maxthon.com/out这个地址是完全一样的,如下图所示。通过这种方式,本地的Ajax就能够读取到其他远程服务器的数据了。
proxy_set_header参数在需要进行域名的转发时使用。Nginx还可以进行端口的转发,只需将proxy_pass配置修改为http://hfahe.maxthon.com:81这种形式即可。&&&&&&&&
2、Apache&&&&&&&& Apache反向代理需要使用mod_proxy和mod_proxy_http.so等模块。&&&&&&&&
在Windows下的配置如下所示:
LoadModule proxy_module modules/mod_proxy.so
LoadModule proxy_http_module modules/mod_proxy_http.so
ProxyRequests Off
ProxyPass /start
ProxyPass /proxy
ProxyPassReverse /proxy
# for server redirect
ProxyPass和ProxyPassReverse指令都是反向代理需要的配置。ProxyPass用于将一个远程服务器映射到本地服务器的URL空间中。而ProxyPassReverse主要解决后端服务器重定向造成的绕过反向代理的问题,在后端服务器会进行服务器端跳转时使用,对HTTP重定向时回应中的Location、Content-Location和URI头里的URL进行调整。&&&&&&&&
而在Linux下的配置如下所示:
LoadModule proxy_module /usr/lib/apache2/modules/mod_proxy.so
LoadModule proxy_http_module /usr/lib/apache2/modules/mod_proxy_http.so
ProxyRequests Off
ProxyPass /fb
ProxyPassReverse /fb
# for server redirect
阅读(...) 评论()没有更多推荐了,
加入CSDN,享受更精准的内容推荐,与500万程序员共同成长!没有更多推荐了,
加入CSDN,享受更精准的内容推荐,与500万程序员共同成长!

我要回帖

更多关于 反向代理解决跨域 的文章

 

随机推荐