上传多个图像会破坏所有图像 - Flask

时间:2017-02-04 23:36:13

标签: python image flask upload

我尝试上传多张图片但文件上的第一张图片除外,所有其他图片在上传过程中都被破坏了。我可以毫无问题地查看第一张图片,但其余图片无法查看。窗户说We can't open this file。这几乎听起来像扩展是未知的。

在旁注中,当我查看其中一个损坏图像的详细信息时,除了底部,文件名等之外,所有字段都是空的。

# view.py 
@myVacation_blueprint.route('/logVacation', methods=['GET', 'POST'])
@login_required
def log_vacation():
form = LogVacationForm()

if request.method == 'POST':
    if form.validate_on_submit():
        try:
            # Get the image name
            uploaded_images = request.files.getlist('photo')
            for image in uploaded_images:
                filename = secure_filename(image.filename)
                # Get the extension
                extension = filename.split('.')[1]
                filename = filename.split('.')[0]
                # Concatenate filename and current time
                filename = str(filename) + str(time.time())
                # Hash the filename
                hash_file_name = bcrypt.generate_password_hash(filename).decode('utf-8')
                # Normalize
                filename = "".join([c if c.isalnum() else "" for c in hash_file_name])
                # Add the extension
                filename = filename + '.' + str(extension)
                # Save the file
                directory = _user_img_folder(form)
                print(os.path.join(directory, filename))
                form.photo.data.save(os.path.join(directory, filename))
        except Exception as e:
            print(e)

        return render_template('myVacation.html')
    else:
        filename = None
return render_template('logVacation.html', form=form, error=error)


# forms.py
class LogVacationForm(FlaskForm):
vacation_name = StringField('Vacation Name', validators=[DataRequired(),   Length(min=6, max=25)])
location = StringField('Location', validators=[DataRequired()])
with_who = StringField('With_Who')
description = TextAreaField('Description', render_kw={
    'class': 'vacation_description',
    'rows': 10
})
photo = FileField('Select Images', validators=[
    # FileRequired(),
    FileAllowed(['jpg', 'png'], 'Images only')],
                  render_kw={'multiple': True}
                  )

# logVacation.html

# many lines....
<form class="logVacation" enctype=multipart/form-data role="form" method="post" action="/logVacation">
# Some other input
{{ form.photo(multiple="multiple") }}
# Some other input
<button class="btn btn-sm btn-success" value="upload" type="submit">Done</button>
</form>

我在这里缺少什么?

注意:我刚注意到view.py form.photo.data的价值在第一个图片名称后永远不会改变。显然,它没有收到其他图像的数据。

1 个答案:

答案 0 :(得分:1)

  • 如果您使用form.validate_on_submit(),则可以删除if request.method == 'POST'

  • .save()方法的对象是文件流(image),而不是表单数据(form.photo.data)。

就像这样:

if form.validate_on_submit():
    for image in request.files.getlist('photo'):
        ...
        image.save(os.path.join(directory, filename))