Jas*_*ass 11 python sqlite flask-sqlalchemy
我正在尝试使用flask构建和应用程序,我看过一些教程和书籍以及一些代码[1],它们解释了如何为数据库设置声明整数和字符串。但是,它们没有解释如何存储图像。我现在很困惑,虽然存储图像的自然方式是在数据库中,但是阅读flask站点[2]上的一些文档,文件系统是存储图像的地方。我只是在阅读 Flask 开发书籍时做出第一个假设,即使用 largeBinary 的声明将是正确的,但这只是我的猜测,正如您在下面的代码中所见。有人可以帮我解决这个问题吗?如果我问的不清楚,请告诉我。
Class User(Base):
__table__ = 'user'
id = Column(Integer, primary_key = True)
name Column(String(80), nullable=False)
email = Column(String(250), nullable=False)
image = Column(LargeBinary, nullable = True)
Run Code Online (Sandbox Code Playgroud)
[1] https://github.com/lobrown/Full-Stack-Foundations/blob/master/Lesson_1/database_setup.py [2] http://flask.pocoo.org/docs/0.10/patterns/fileuploads/
有一个名为SQLAlchemy-ImageAttach的库,它提供了一种创建具有图像对象的实体的方法。这些可以通过一些网址公开。
否则,您可以通过SingleImageSet
该类直接获取文件对象。
使用 lib,您可以从两个存储中进行选择,例如文件系统或 Amazon 的 S3。在文档中,有一个描述的示例(灰色框)如何预先定义存储,然后定义一个 User 实体并拥有一个 UserPicture 实体。
from sqlalchemy import Column, ForeignKey, Integer, Unicode
from sqlalchemy.orm import relationship
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy_imageattach.entity import Image, image_attachment
Base = declarative_base()
class User(Base):
"""User model."""
id = Column(Integer, primary_key=True)
name = Column(Unicode, nullable=False)
picture = image_attachment('UserPicture')
__tablename__ = 'user'
class UserPicture(Base, Image):
"""User picture model."""
user_id = Column(Integer, ForeignKey('user.id'), primary_key=True)
user = relationship('User')
__tablename__ = 'user_picture'
Run Code Online (Sandbox Code Playgroud)
我不知道 Flask,但也许您可以通过一些 wsgi 声明和此处的 Lib 来使用文件存储。我希望它对你有所帮助,并给你一些**。
我在这篇文章 [1] 中读到,最好的方法是将图像字段声明为字符串来保存图像的 url 或链接,然后图像可以存储在与应用程序的服务器不同的外部服务器中。因此,如果有人有同样的疑问,只需将其声明为字符串并继续您的应用程序开发。对数据库管理系统有点失望,它们只能用于存储数字和字母数据(:p)。
[1] https://www.reddit.com/r/flask/comments/31tywp/afbest_way_to_store_avatars_images_etc/
归档时间: |
|
查看次数: |
13952 次 |
最近记录: |