Created
August 14, 2015 03:02
-
-
Save liulixiang1988/cc3093b2d8cced6dcf38 to your computer and use it in GitHub Desktop.
upload multiple files in Flask
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
import os | |
# We'll render HTML templates and access data sent by POST | |
# using the request object from flask. Redirect and url_for | |
# will be used to redirect the user once the upload is done | |
# and send_from_directory will help us to send/show on the | |
# browser the file that the user just uploaded | |
from flask import Flask, render_template, request, redirect, url_for, send_from_directory | |
from werkzeug import secure_filename | |
# Initialize the Flask application | |
app = Flask(__name__) | |
# This is the path to the upload directory | |
app.config['UPLOAD_FOLDER'] = 'uploads/' | |
# These are the extension that we are accepting to be uploaded | |
app.config['ALLOWED_EXTENSIONS'] = set(['txt', 'pdf', 'png', 'jpg', 'jpeg', 'gif']) | |
# For a given file, return whether it's an allowed type or not | |
def allowed_file(filename): | |
return '.' in filename and \ | |
filename.rsplit('.', 1)[1] in app.config['ALLOWED_EXTENSIONS'] | |
# This route will show a form to perform an AJAX request | |
# jQuery is loaded to execute the request and update the | |
# value of the operation | |
@app.route('/') | |
def index(): | |
return render_template('index.html') | |
# Route that will process the file upload | |
@app.route('/upload', methods=['POST']) | |
def upload(): | |
# Get the name of the uploaded files | |
uploaded_files = request.files.getlist("file[]") | |
filenames = [] | |
for file in uploaded_files: | |
# Check if the file is one of the allowed types/extensions | |
if file and allowed_file(file.filename): | |
# Make the filename safe, remove unsupported chars | |
filename = secure_filename(file.filename) | |
# Move the file form the temporal folder to the upload | |
# folder we setup | |
file.save(os.path.join(app.config['UPLOAD_FOLDER'], filename)) | |
# Save the filename into a list, we'll use it later | |
filenames.append(filename) | |
# Redirect the user to the uploaded_file route, which | |
# will basicaly show on the browser the uploaded file | |
# Load an html page with a link to each uploaded file | |
return render_template('upload.html', filenames=filenames) | |
# This route is expecting a parameter containing the name | |
# of a file. Then it will locate that file on the upload | |
# directory and show it on the browser, so if the user uploads | |
# an image, that image is going to be show after the upload | |
@app.route('/uploads/<filename>') | |
def uploaded_file(filename): | |
return send_from_directory(app.config['UPLOAD_FOLDER'], | |
filename) | |
if __name__ == '__main__': | |
app.run( | |
host="0.0.0.0", | |
port=int("80"), | |
debug=True | |
) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
<!DOCTYPE html> | |
<html lang="en"> | |
<head> | |
<link href="//netdna.bootstrapcdn.com/bootstrap/3.0.0/css/bootstrap.min.css" | |
rel="stylesheet"> | |
</head> | |
<body> | |
<div class="container"> | |
<div class="header"> | |
<h3 class="text-muted">How To Upload a File</h3> | |
</div> | |
<hr/> | |
<div> | |
<form action="upload" method="post" enctype="multipart/form-data"> | |
<input type="file" multiple="" name="file[]" class="span3" /><br /> | |
<input type="submit" value="Upload" class="span2"> | |
</form> | |
</div> | |
</div> | |
</body> | |
</html> | |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
<!DOCTYPE html> | |
<html lang="en"> | |
<head> | |
<link href="//netdna.bootstrapcdn.com/bootstrap/3.0.0/css/bootstrap.min.css" | |
rel="stylesheet"> | |
</head> | |
<body> | |
<div class="container"> | |
<div class="header"> | |
<h3 class="text-muted">Uploaded files</h3> | |
</div> | |
<hr/> | |
<div> | |
This is a list of the files you just uploaded, click on them to load/download them | |
<ul> | |
{% for file in filenames %} | |
<li><a href="{{url_for('uploaded_file', filename=file)}}">{{file}}</a></li> | |
{% endfor %} | |
</ul> | |
</div> | |
<div class="header"> | |
<h3 class="text-muted">Code to manage a Upload</h3> | |
</div> | |
<hr/> | |
<pre> | |
@app.route('/upload', methods=['POST']) | |
def upload(): | |
# Get the name of the uploaded file | |
#file = request.files['file'] | |
uploaded_files = request.files.getlist("file[]") | |
filenames = [] | |
for file in uploaded_files: | |
# Check if the file is one of the allowed types/extensions | |
if file and allowed_file(file.filename): | |
# Make the filename safe, remove unsupported chars | |
filename = secure_filename(file.filename) | |
# Move the file form the temporal folder to the upload | |
# folder we setup | |
file.save(os.path.join(app.config['UPLOAD_FOLDER'], filename)) | |
filenames.append(filename) | |
# Redirect the user to the uploaded_file route, which | |
# will basicaly show on the browser the uploaded file | |
# Load an html page with a link to each uploaded file | |
return render_template('upload.html', filenames=filenames) | |
</pre> | |
</div> | |
</div> | |
</body> | |
</html> | |
using send from directory
I think you can't
using send from directory
Because of security reasons of browser
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
how to add two path to show images from two diffrent folder