目录
- 前言
- 1. 接口方式
- 2. Nginx
前言
基本项目的构建推荐阅读:构建Flask前后端不分离项目(附Python Demo)
对于Java的基本知识,推荐阅读:
- java框架 零基础从入门到精通的学习路线 附开源项目面经等(超全)
- 【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的详细说明,更多的了解,推荐阅读:
- Nginx从入门到精通(全)
- Nginx配置静态网页访问(图文界面)
- 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 创建的证书路径