Nginx系列之代理之后无法加载静态资源处理方法

Stella981
• 阅读 867

最近在跟https域名升级问题,遇到一个麻烦的任务,因为域名由另外的公司负责,对方公司开了一个nginx服务器做了类似的转发

location /zhzw {
   
   
   
        proxy_pass http://127.0.0.1:81/zhzw;
        #rewrite  ^/zhzw/(.*)$ /$1 break;
}

公司内部的nginx

 server {
        listen       81;
        server_name  localhost;
        location /zhzw/Portal { 
               proxy_pass  http://127.0.0.1:8081/zhzw/Portal;
               proxy_set_header        Host $host;
               proxy_set_header        X-Real-IP $remote_addr;  #获取真实ip
               proxy_connect_timeout   90;
               proxy_send_timeout      90;
               proxy_read_timeout      90;
               proxy_buffer_size       4k;
               proxy_buffers           4 32k;
               proxy_busy_buffers_size 64k;
               proxy_temp_file_write_size 64k;
               proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;#获取代理者的真实ip
               proxy_redirect          off;  
               proxy_set_header X-Forwarded-Proto $scheme;
        }
    ## ... 省略
}

tomcat conf/server.xml配置,在<Engine>里加上配置

<Context docBase="D:\apache-tomcat-7.0.77\webapps\Portal "  reloadable="true"  debug="0" path="/zhzw/Portal "></Context>

其中http://127.0.0.1:81是我们公司的nginx,接着我们的nginx再做转发,看起来好像没问题,其实是带来了很多问题,比如在前端页面的资源是用相对路径的,是不能获取到转发过来的域名后缀/zhzw ,所以就一堆404问题,所以先尝试能不能过滤后缀/zhzw,nginx修改,可以使用斜杆的方法或者rewrite,网上很多地方都有介绍

 server {
        listen       81;
        server_name  localhost;
        location /zhzw/Portal/ { 
               proxy_pass  http://127.0.0.1:8081/zhzw/Portal/;
               proxy_set_header        Host $host;
               proxy_set_header        X-Real-IP $remote_addr;  #获取真实ip
               proxy_connect_timeout   90;
               proxy_send_timeout      90;
               proxy_read_timeout      90;
               proxy_buffer_size       4k;
               proxy_buffers           4 32k;
               proxy_busy_buffers_size 64k;
               proxy_temp_file_write_size 64k;
               proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;#获取代理者的真实ip
               proxy_redirect          off;  
               proxy_set_header X-Forwarded-Proto $scheme;
                rewrite  ^/Portal/(.*)$ /$1 break;
        }
    ## ... 省略
}

这种方式代理后,静态资源都加载不到,所以需要再加上如下配置:

location ~ .* {
            proxy_pass http://127.0.0.1:8081;
            proxy_set_header Host $http_host;
            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
}

ok,经过摸索,这种方式也是不支持相对路径的,所以只能改代码实现,设置一个全局变量,然后全局替换相对路径

String requestUrl = request.getHeader("Referer");
if (requestUrl == null || requestUrl == "") {
   
   
   
    requestUrl = request.getRequestURL().toString();
}
URL url = new URL(requestUrl);
String schema = url.toURI().getScheme();
String host = url.getHost();
String domain = schema + "://" + host + "/zhzw";
//System.out.println(String.format("requestUrl : %s , host : %s , domain : %s" , requestUrl, host, domain));
request.setAttribute("domain", domain);

ok,本博客记录一下,因为这个问题是有点棘手,暂时找不到好的方法,只想到这种全局改代码的方法,其实二级域名是一种方法,不过协商不到

本文同步分享在 博客“smileNicky”(CSDN)。
如有侵权,请联系 support@oschina.cn 删除。
本文参与“OSC源创计划”,欢迎正在阅读的你也加入,一起分享。

点赞
收藏
评论区
推荐文章
nginx根据url中的参数做代理转发
功能:一个nginx代理转发,代理目标地址来自url中的host参数location/ errorpage418@other; recursiveerrorpageson; resolver1.2.4.8; set$host''; if($querystringhost(http(s)?:\/\/^\/(.com|
待兔 待兔
4个月前
手写Java HashMap源码
HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程22
Stella981 Stella981
3年前
Nginx系列之使用ssl模块配置支持代理HTTPS链接
Nginx系列之使用ssl模块配置支持HTTPS访问1、博客前言介绍最近在用nginx代理https的第三方链接,因为不是做运维,所以对nginx并不是特殊熟悉,所以到处询问摸索了挺久2、查看ssl\_module要使用nginx代理https的链接,先用检查nginx是否已经有安装了ssl
Wesley13 Wesley13
3年前
NGINX配置入门
Nginx是一个轻量级高性能的web服务器,它是为快速响应大量静态文件请求和高效利用系统资源而设计的。与apache使用面向进程或线程的方式处理请求不同,nginx使用异步事件驱动模型在负载下性能更突出。虽然nginx能高效地服务静态文件,但也有人认为nginx处理动态内容并不理想。不像apache服务器,nginx没用使用内嵌解释器的方式来处理动态内容
Stella981 Stella981
3年前
Nginx域名解析流程,源码分析
!(https://oscimg.oschina.net/oscnet/4a351a07169648d098175fedb4775d338e0.gif"键盘动图引导关注")nginx在做正向代理、反向代理的时候,或upstream使用域名的时候,要做频繁的域名解析,为了更快的响应,nginx有一套自己的域名解析过程!(https:/
Stella981 Stella981
3年前
Nginx 简单配置域名跳转
暂时用到这么多,简单记录下首先要买个域名去买域名的网站后台管理配置域名解析,设置跳转到服务器公网ip直接访问公网ip的结果是访问80端口,一般web应用并不是,如tomcat默认8080服务器安装Nginx修改Nginx配置文件,转发80端口收到的请求到web应用的真实地址使生效
Easter79 Easter79
3年前
Tengine 添加第三方监控模块nginx
一、概述  除nginx官网源码提供的各种模板,nginx还有第三方模块。官方文档中也列出了nginx的很多第三方模块,除官网之外,还有很多的有用的模块也能在Github上找到。官网第三方模块地址:https://www.nginx.com/resources/wiki/modules/公司前端使用的是nginx代理,反向代理了很多域名
Stella981 Stella981
3年前
Cocos Creator 资源加载流程剖析【三】——Load部分
Load流程是整个资源加载管线的最后一棒,由Loader这个pipe负责(loader.js)。通过Download流程拿到内容之后,需要对内容做一些“加载”处理。使得这些内容可以在游戏中使用。这里并不是所有的资源都需要进行一个加载处理,目前只有图片、Json、Plist、Uuid(Prefab、场景)等资源才会执行加载的流程,其他的资源在Downloa
Stella981 Stella981
3年前
Nginx负载均衡
前面我们说了反向代理,例子中用的是,两个请求请求同一个ip地址和端口,然后Nginx来根据域名调用不同的tomcat来进行请求处理及响应。反向代理主要说的是:不同的请求请求同一个Nginx服务器,Nginx服务器来决定由那个真正的业务服务器(eg:tomcat)处理某个请求。下面说负载均衡负载均衡一般是指,针对同一个(域名的)请求发送很多次,同
ZOS对象存储跨域资源访问的实现和使用
跨域指的是从一个域名去请求另外一个域名的资源,即跨域名请求。跨域时,浏览器不能执行其他域名网站的脚本,这是由浏览器的同源策略造成的,是浏览器施加的安全限制。同源策略是一种约定,是浏览器最核心也最基本的安全功能,不同源的客户端脚本在没有明确授权的情况下,不能读写对方资源,这是一个用于隔离潜在恶意文件的重要安全机制。