详细分析python下载文件的两种方式(附Demo)

前言

基本项目的构建推荐阅读:构建Flask前后端不分离项目(附Python Demo)

对于Java的基本知识,推荐阅读:

  1. java框架 零基础从入门到精通的学习路线 附开源项目面经等(超全)
  2. 【Java项目】实战CRUD的功能整理(持续更新)

1. 接口方式

对于flask1.0的版本可以使用如下方式(通过接口)

from flask import Flask, send_file, abort

app = Flask(__name__)

@app.route('/download/<filename>')
def download_file(filename):
    try:
        # 文件路径
        file_path = f'/path/to/your/files/{filename}'
        
        # 确保文件存在
        if not os.path.isfile(file_path):
            abort(404)  # 文件不存在,返回 404 错误

        # 发送文件
        return send_file(file_path, as_attachment=True, attachment_filename=filename)
    except Exception as e:
        # 捕获异常并返回 500 错误
        return str(e), 500

if __name__ == '__main__':
    app.run(debug=True)

以上只是作为展示

如果是前后进行交互,基本的Demo如下:(flask2.0版本)

from flask import Blueprint, render_template, send_file

bp = Blueprint('main', __name__)

@bp.route('/')
def index():
    return render_template('index.html')


@bp.route('/download')
def download():
    # 假设压缩包文件路径为 '/path/to/your/file.zip'
    file_path = '/root/xx.rar'
    return send_file(file_path, as_attachment=True, download_name='xx.rar')

对于前端的按钮配置如下:

<button onclick="downloadFile()">下载压缩包</button> <!-- 新增的下载按钮 -->

后续只需要把对应文件放置在相应位置即可

截图如下:

在这里插入图片描述

2. Nginx

对于Nginx的详细说明,更多的了解,推荐阅读:

  1. Nginx从入门到精通(全)
  2. Nginx配置静态网页访问(图文界面)
  3. Nginx将https重定向为http进行访问的配置(附Demo)

总体配置如下:

server {
    listen 80;
    server_name ip地址;

    location / {
        proxy_pass http://127.0.0.1:5000;
        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_set_header X-Forwarded-Proto $scheme;
    }

    location /downloads/ {
        alias /path/to/your/files/;
        autoindex on; # 可选:启用目录索引
    }
}

前端的ip地址只需要走对应的链接即可

<a href="https://ip/downloads/光纤配置表生成.rar" download>下载压缩包</a>

这种方式适合内网,如果外网需要配置相应的域名证书之类的

在服务器上安装 Certbot 工具,以便为域名申请 SSL 证书:

sudo apt update
sudo apt install certbot python3-certbot-nginx

获取证书
使用 Certbot 获取并安装 SSL 证书:

sudo certbot --nginx -d your_domain

将 your_domain 替换为域名。如果使用的是 IP 地址而不是域名,可能需要设置一个有效的域名

配置 Nginx 使用 HTTPS,Certbot 会自动配置 Nginx 来使用 HTTPS
如果需要手动配置,请确保Nginx 配置文件如下所示:

server {
    listen 80;
    server_name ip地址;

    location / {
        proxy_pass http://127.0.0.1:5000;
        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_set_header X-Forwarded-Proto $scheme;
    }

    location /downloads/ {
        alias /root/;
        autoindex on; # 启用目录索引(可选)
    }

    # Redirect HTTP to HTTPS
    location / {
        return 301 https://$host$request_uri;
    }
}

server {
    listen 443 ssl;
    server_name ip地址;

    ssl_certificate /etc/letsencrypt/live/your_domain/fullchain.pem;
    ssl_certificate_key /etc/letsencrypt/live/your_domain/privkey.pem;

    location / {
        proxy_pass http://127.0.0.1:5000;
        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_set_header X-Forwarded-Proto $scheme;
    }

    location /downloads/ {
        alias /root/;
        autoindex on; # 启用目录索引(可选)
    }
}

请确保替换 /etc/letsencrypt/live/your_domain/fullchain.pem 和 /etc/letsencrypt/live/your_domain/privkey.pem 路径为 Certbot 创建的证书路径

  • 11
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

码农研究僧

你的鼓励将是我创作的动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值