Nginx指令add_header和proxy_set_header的区别及说明
作者:叹人间,美中不足今方信
这篇文章主要介绍了Nginx指令add_header和proxy_set_header的区别及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
Nginx指令add_header和proxy_set_header区别
如何理解反向代理?
Nginx
是反向代理服务器,我们可以从下面的图来理解为什么是反向代理。
以Nginx
为中心,数据的流向是从Server
到Nginx
再到Client
,注意我说的是数据(响应数据),而不是请求。
我们都知道水流一定是从上游流到下游,所以给Server
一个别称上游服务器,当然这个别称并不是我定义的。
proxy_set_header和add_header的区别
区别:proxy_set_header
是Nginx
设置请求头信息给上游服务器,add_header
是Nginx
设置响应头信息给浏览器。
proxy_set_header
假如Nginx
请求上游服务器时,添加额外的请求头,就需要使用proxy_set_header
。
在Java
中使用HttpServletRequest#getHeader(String name)
来获取请求头的值,name
是请求头的名称。
例如:
proxy_set_header X-Request-URI $scheme://$host/$uri;
String requestUrl = request.getHeader("X-Request-URI"); if (requestUrl == null) { // 从Servlet服务器获取客户端请求地址 requestUrl = request.getRequestURL().toString(); }
add_header
Nginx
响应数据时,要告诉浏览器一些头信息,就要使用add_header
。
例如:跨域访问(详细参见Nginx跨域访问配置)
add_header 'Access-Control-Allow-Origin' '*'; add_header 'Access-Control-Allow-Headers' 'X-Requested-With'; add_header 'Access-Control-Allow-Methods' 'GET,POST,OPTIONS' # 由于跨域请求,浏览器会先发送一个OPTIONS的预检请求,我们可以缓存第一次的预检请求的失效时间 if ($request_method = 'OPTIONS') { add_header 'Access-Control-Max-Age' 2592000; add_header 'Content-Type' 'text/plain; charset=utf-8'; add_header 'Content-Length' 0; return 204; }
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。