配置FTP目录文件以http网址方式访问并下载

1、功能例图

2、配置nginx进行转发

首先在linux服务器上配置 nginx 进行访问存放文件的服务器地址,

例如:我本地是 /home/enjoy/files/ 作为文件目录

在linux上安装 nginx 后可进行代码文件地址,

安装步骤如下:

复制代码
# 1. 安装依赖
yum install -y gcc gcc-c++ make pcre-devel zlib-devel openssl-devel
# 2. 下载Nginx(以1.24.0为例)
wget http://nginx.org/download/nginx-1.24.0.tar.gz
tar -zxvf nginx-1.24.0.tar.gz
cd nginx-1.24.0
# 3. 配置编译路径
./configure --prefix=/usr/local/nginx
# 4. 编译安装
make && make install
# 5. 创建日志目录(确保存在)
mkdir -p /usr/local/nginx/logs
# 6. 启动Nginx
/usr/local/nginx/sbin/nginx
# 7. 验证
curl localhost  # 输出Nginx默认页面即成功

安装nginx可参考如下地址:

​​​​​​--- https://blog.csdn.net/m0_74824091/article/details/144771841

--- https://blog.51cto.com/u_16099267/13340356

也可以自己百度处理

注意项:配置启动 nginx的 登录用户就是nginx的 使用用户,在之后配置账号信息时有用

3、配置地址访问的账号信息

方案A:使用Nginx标准配置路径

复制代码
# 创建标准密码文件路径
sudo mkdir -p /etc/nginx/conf.d
sudo touch /etc/nginx/conf.d/.htpasswd

# 生成密码
sudo sh -c "echo 'enjoy:$(openssl passwd -apr1 123456)' > /etc/nginx/conf.d/.htpasswd"

# 设置权限
sudo chmod 644 /etc/nginx/conf.d/.htpasswd
sudo chown nginx:nginx /etc/nginx/conf.d/.htpasswd

方案B:使用用户目录安全路径

复制代码
# 创建安全目录
sudo mkdir -p /home/enjoy/nginx_conf
sudo touch /home/enjoy/nginx_conf/.htpasswd

# 生成密码
sudo sh -c "echo 'enjoy:$(openssl passwd -apr1 123456)' > /home/enjoy/nginx_conf/.htpasswd"

# 设置权限
sudo chmod 600 /home/enjoy/nginx_conf/.htpasswd
sudo chown enjoy:enjoy /home/enjoy/nginx_conf/.htpasswd

📝 Nginx配置调整

在nginx.conf中添加:

复制代码
server {
	listen 9090;
	server_name localhost;

	location /files/ {
		alias /home/enjoy/files/;
		autoindex on;                # 启用目录浏览
		autoindex_exact_size off;    # 显示友好文件大小
		autoindex_localtime on;      # 显示本地时间
		
		# 身份验证配置
		auth_basic "Restricted Access";
		auth_basic_user_file /home/enjoy/nginx_conf/.htpasswd;  # 方案B路径
		
		# 强制下载配置
		add_header Content-Disposition 'attachment; filename="$host$request_uri"';
	}
}

✅ 验证步骤

  • 检查路径有效性

    sudo ls -l /etc/nginx/conf.d/.htpasswd # 方案A
    sudo ls -l /home/enjoy/nginx_conf/.htpasswd # 方案B

  • 重载Nginx

    sudo nginx -t
    sudo systemctl reload nginx

  • 访问测试

    curl -u enjoy:123456 http://localhost:9090/files/aaa.png --output downloaded.png

🛡️ 注意事项

  • 在步骤一时提到,启动nginx的登录账号就是 nginx的账号,在之后的所有授权账号中都应该使用此账号信息
  • 在转发过程中所使用到的所有文件夹、文件都需要进行账号授权(和nginx启动账号一样)
  • 在启动nginx过程中,注意是否存在logs 文件信息,并及时查看 error.log ,查看对应错误日志
相关推荐
数据法师16 分钟前
开源情报收集工具GhostTrack深度测评:IP、手机号、用户名的合规信息查询方案
网络·网络协议·tcp/ip
丑八怪大丑1 小时前
Java网络编程
linux·服务器·网络
想成为优秀工程师的爸爸2 小时前
第三十篇技术笔记:郭大侠学UDS - 人有生老三千疾,望闻问切良方医
网络·笔记·网络协议·tcp/ip·信息与通信
数智工坊3 小时前
【SAM-DETR论文阅读】:基于语义对齐匹配的DETR极速收敛检测框架
网络·论文阅读·人工智能·深度学习·transformer
时空自由民.4 小时前
蓝牙协议之GAP协议
linux·服务器·网络
灰子学技术4 小时前
Envoy HTTP Connection Manager (HCM) 技术文档
网络·网络协议·http
byoass4 小时前
企业云盘与设计软件深度集成:AutoCAD/Revit/SolidWorks插件开发与API集成实战
服务器·网络·数据库·安全·oracle·云计算
智慧光迅AINOPOL4 小时前
全光网设备厂家选型参考:评估要点与技术标准说明
网络·全光网解决方案·全光网·酒店全光解决方案·泛住宿全光网解决方案
qq_三哥啊5 小时前
【mitmproxy】提取 OpenCode 的 API 接口
网络·代理模式
dog2505 小时前
圆锥曲线和二次曲线
开发语言·网络·人工智能·算法·php