我的编程空间,编程开发者的网络收藏夹
学习永远不晚

PHP Nginx静态资源转临时地址访问

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

PHP Nginx静态资源转临时地址访问

前言

很多小伙伴对Nginx并不陌生,来代理网站页面或者代理文件资源,配置简单,灵活。但是若出现像带权限的来访问Nginx的静态资源时,那简单的配置将不生效。

需求

公司渗透测试扫描发现了一个未授权访问文件的问题,即外网可以通过文件地址直接访问文件服务器中文件,无需任何认证,造成公司敏感数据泄露。

需要分析

我们的文件地址形如:http://y.y.y.y/video/2022/11/26/video_202211260104258u6j16128.mp4(y.y.y.y是应用服务器IP或域名)
1、请求地址到应用服务器
2、应用服务器(x.x.x.x)再通过nginx转发到文件服务器,获取到对应文件。
3、获取到文件后直接返回,如果是返回前端,即可做图片预览,文件下载,视频播放等功能。此外中台应用功能,如发送邮件时,也是直接调用的文件地址获取附件。
该地址是在应用服务器通过nginx直接转发到文件服务器的,没有经过应用系统鉴权,好处就是获取文件无需暂用应用服务器带宽,速度较快。但也产生了未授权访问的问题。
流程如下:
在这里插入图片描述

准备

需要用到的只是,工具
thinkphp
nginx
一些文件

具体实现

应用服务器Nginx配置

server{    listen       80;    listen  [::]:80;        .    .    .    # 视频地址前缀    location /file {        proxy_redirect off;        proxy_set_header Host  $host;        proxy_set_header X-Real-IP $remote_addr;        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;        # 指定提供文件鉴权服务的地址        proxy_pass http://x.x.x.x/index/auth;    }    # 静态资源前缀    location /resource{        internal;        proxy_pass http://y.y.y.y/;    }}

业务代码

path), rand(0, 24), 8)            . "-"            . substr(md5($this->path), rand(0, 28), 4)            . "-"            . substr(md5($this->path), rand(0, 28), 4)            . "-"            . substr(md5($this->path), rand(0, 28), 4)            . "-"            . substr(md5($this->path), rand(0, 20), 12);    }// 获取视频地址接口    public function getFilePath(): string    {        $str = $this->random();        $this->app->cache->set($str, $this->path);        $result = $this->local_domain . 'video?path=' . $str;        return "";    }// 判断当前视频是否访问过,访问过“地址失效”,否则可以访问    public function auth(Request $request) {        $path = $request->get('path');        if (!empty($request->header('referer'))) {             $res = $this->app->cache->get($path);             if ($res) {                 header('X-Accel-Redirect: ' . $this->route . $res);             } else {                 echo "地址失效";             }        } else {            echo "地址失效";        }    }}

请求

http://x.x.x.x/index/getFilePath#生成临时视频地址,返回给前端视频播放标签#前端视频渲染自动请求server里 /file# nginx代理到authhttp://x.x.x.x/index/auth# 检测当前视频链接是否被访问过,访问过,连接失效,否则,正常执行# 注意:此处为重点 header内X-Accel-Redirect 就是回调Nginx静态前缀的关键所在前面所提到的允许内部访问,即此处处理# header('X-Accel-Redirect: ' . $this->route . $res); ; 内连接请求server里面的/resource# 然后跳转到文件服务器http://y.y.y.y/video/2022/11/26/video_202211260104258u6j16128.mp4'

来源地址:https://blog.csdn.net/weixin_44961480/article/details/128074005

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

PHP Nginx静态资源转临时地址访问

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

nginx访问静态资源

nginx访问静态资源 打开nginx配置文件 1 打开 nginx.conf 文件 2 修改 nginx.conf 内容 只需修改成或者添加一个location,就可以访问 html路径下所有文件了 loc
2023-08-18

Nginx访问本地静态资源详细步骤(推荐)

Nginx (engine x) 是一个高性能的HTTP和反向代理web服务器,同时也提供了IMAP/POP3/SMTP服务,这篇文章主要介绍了nginx配置访问本地静态资源,需要的朋友可以参考下
2022-12-08

解决nginx/apache静态资源跨域访问问题详解

1. apache静态资源跨域访问找到apache配置文件httpd.conf 找到这行 #LoadModule headers_module modules/mod_headers.so把#注释符去掉 LoadModule headers
2022-06-04

linux服务器上使用nginx访问本地静态资源的方法

1.查看80端口是否被占用,一般80端口多被apache服务占用。 netstat -anp|grep 80 2.修改apache服务的端口号 vim /etc/apache2/ports.conf3.将
2022-06-04

怎么使用nginx代理实现静态资源访问

今天小编给大家分享一下怎么使用nginx代理实现静态资源访问的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。一. 目标:为了通
2023-07-02

nodejs构建本地web测试服务器 如何解决访问静态资源问题

直接打开html文件,是以file:///方式打开的,这种方式很多时候会遇到跨域的问题,因此我们一般会搭建一个简易的本地服务器,来运行测试页面。 一、构建静态服务器 1、使用express模块 建立个js文件,命名server,内容代码如下
2022-06-04

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录