一灌闺、需求提出
- 在一個以flask為框架的項目中顷编,有時需要把上傳的圖片存入數(shù)據(jù)庫以保障不易丟失灵份。
二、原理
- 以二進制流的形式把上傳的圖片存入數(shù)據(jù)庫
三沉眶、實踐
(1)app/models.py中的主要代碼如下:
class ImageFile(db.Model):
__tablename__ = 'ImageFile'
id = db.Column(db.Integer, primary_key=True)
image_name = db.Column(db.String(30), index=True)
image = db.Column(db.LargeBinary(length=2048))
其中存儲圖片時用到的字段類型為 db.LargeBinary 打却,這個類型就是用來儲存二進制文件的。
(2)app/main/forms.py表單類的代碼如下:
from flask_wtf import Form
from wtforms import StringField, FileField, SubmitField
class upForm(Form):
name = StringField('Name')
file = FileField('file')
submit = SubmitField('submit')
(3)app/main/views.py視圖函數(shù)主要代碼如下:
import base64
@main.route('/', methods=['GET', 'POST'])
def upload():
ds = ImageFile.query.all()
form = upForm()
if request.method == 'POST' and form.validate():
file = request.files['file'].read()
file_name = form.name.data
image_file = ImageFile(image_name=file_name, image=file)
db.session.add(image_file)
db.session.commit()
flash('ok')
return redirect(url_for('.upload'))
return render_template('up.html', form=form, ds=ds, base64=base64)
其中用request.files['file']的read()方法把圖片數(shù)據(jù)讀出來谎倔,然后進行數(shù)據(jù)庫的儲存柳击。在顯示時要用到base64這個庫
(4)templates/up.html的模板文件中的主要代碼如下:
{% extends "base.html" %}
{% block page_content %}
<div style="width: 85%;margin-left: 2%;">
<form action="" method="post" name="" enctype="multipart/form-data">
{{form.hidden_tag()}}
{{ form.name }}
{{ form.file(required="required") }}
{{ form.submit }}
</form>
----------------------------------------------------------------------------------
{% if ds %}
{% for d in ds%}
<p> {{ d.image_name }}---<img src="data:;base64,{{ base64.b64encode(d.image) }}"/></p>
{% endfor %}
{% endif %}
</div>
{% endblock %}
在form表單元素中不要忘記加了enctype="multipart/form-data"這個屬性。他能保證文件的完整傳輸片习。