解决反向代理的样式表丢失问题

前言

最近作者斥巨资白嫖了云服务器,想在云服务器上面搭建靶场,为了能实现在容器上面搭建多个靶场,我一开始想到使用docker搭建多个容器,并通过访问容器映射的端口就可以实现,但是由于脑子抽了,想试一下能不能使用nginx反向代理,通过在URL上面输入不同靶场的名称,然后跳转到不同的靶场容器,达到只使用80端口就能访问不同靶场的目的。所以开始了我的尝试。

环境信息

OS: Linux 3.10.0-957.21.3.el7.x86_64
RELEASE: CentOS Linux release 7.6.1810 (Core)
NGINX: nginx version: nginx/1.22.1
DOCKER: Docker version 23.0.1, build a5ee5b1

拓扑环境

靶场1(容器1):sqli-maps 127.0.0.1:8001 靶场2(容器2):upload-labs 127.0.0.1:8001

配置过程

1、下载靶场的docker镜像并运行

sqli-labs

docker run -dt --name sqli-lab -p 8001:80 acgpiano/sqli-labs:latest

upload-labs

docker run -dt --name upload-labs -p 8002:80 c0ny1/upload-labs:latest

2、修改nginx的配置文件

找到Nginx服务器下面的 conf 文件夹下的 nginx.conf 配置文件

添加如下信息

server {
    listen 80;
    server_name your.domain;
​
    location /sqli-labs/ {
        proxy_pass http://127.0.0.1:8001/;
    }
    
    location /upload-labs/ {
        proxy_pass http://127.0.0.1:8002/upload-labs/;
        
    }

3、发现css样式表和其他静态资源存在问题

可以看到样式表和静态文件均为容器内部的URI,并不是我们需要访问的实际的URI

4、失败的尝试

参考nginx官方文档 Serving Static Content | NGINX Plus 配置很多参数

如:在配置文件中添加如下参数

或者添加

==均未成功!==

5、成功的方法

通过询问Jin大佬了解到

造成的原因是因为我的容器内部的URI和外部的URI不匹配,因此我转换思路,尽然在代理这儿行不通,我就去修改容器的内容部文件

使用docker命令进入容器查看,发现docker镜像是直接在网站的根目录下,并且所有的文件都是用的PHP的魔术常量来引用,因此我直接在根目录下新建了一个upload-labs文件夹,与反向代理配置的一致。这样就能达到两边的URI统一了。

docker exec -it <containerid> /bin/bash

进入容器使用命令修改完成

配置成功

  • sqli-labs

  • upload-labs

总结

当使用Nginx配置反向代理时,如果遇到代理的网站资源不能正确加载,有以下几种可能

1、检查CSS和图像文件的路径,如果通过配置nginx文件不能解决,就保证代理网站和nginx的URI统一

2、配置Nginx的配置文件,通过修改一些参数来实现转发URL(但是我没有用这个方法成功)

3、检查静态资源的文件权限

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
随着Web应用程序的不断发展,越来越多的Web开发者需要处理跨域访问的问题。尤其在网站开发中,标签<iframe>存在一些跨域问题,需要得到解决解决这些问题的一种方案是使用反向代理服务器。Nginx是一个功能强大的开源服务器软件,可以用来提供反向代理服务,也可以作为Web服务器、邮件服务器和负载均衡器。 在使用Nginx作为反向代理服务器时,可以按如下步骤解决iframe跨域问题: 1.安装和配置Nginx。首先,您需要在服务器上安装Nginx,并确保nginx.conf文件正确配置。配置反向代理服务器,将请求从原始服务器发送到新的服务器。 2.设置虚拟主机。为了使Nginx适用于您的网站,需要设置虚拟主机,配置主机的ip格式和端口号。通常情况下,虚拟主机可以支持多个域名和主机名,可以同时接收多个请求。 3.设置location指令。为了完成反向代理任务,可以使用location指令,将请求传递给正确的服务器,并且从指定的URL获取响应。具体而言,您需要在nginx.conf文件中指定location指令,并告诉Nginx需要向哪个服务器发送请求。 4.启用SSL。如果您的网站需要安全的传输,比如HTTPS,那么您可以使用SSL/TLS加密功能。在Nginx中配置SSL,需要使用SSL module或者OpenSSL来启用。 总之,Nginx是一个非常强大的反向代理服务器,可以很好地解决网站开发中的问题。利用其反向代理功能,您可以很容易地解决iframe跨域访问的问题,确保您的Web应用程序能够正常运行并保持安全性和高可用性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值