1

我正在开发一个 REST python 应用程序,并且我选择flask_restless构建连接到数据库的端点。我想管理的表之一是将二进制文件存储为 blob ( LargeBinary)。不过,我注意到,flask_restlessPOST 请求需要 json 数据。我尝试将 base64 应用于二进制文件内容并用 json 包装,但最终flask_restless将文件内容作为字符串传递给 sqlalchemy,并且 SQLite 后端抱怨它需要字节输入(非常正确)。我尝试在互联网上搜索解决方案,但要么我的查询不正确,要么实际上没有。

那么,有没有办法配置受管理的端点flask_restless以接受二进制文件作为附件?或者更确切地说,建议的解决方案是直接使用烧瓶为该特定表设置端点(我之前在另一个应用程序中做过),远离flask_restless?

4

1 回答 1

1

事实证明,发送附件是不可能的。因此,我深入研究了如何发送 base64 编码的附件,然后将这些附件保存为 blob。

为此,我使用了以下预处理和后处理设施flask_restless

def pp_get_single_image(result=None, **kw):
    import base64
    result['image'] = base64.b64encode(result['image']).decode('utf8')

def pp_get_many_images(result=None, search_params=None, **kw):
    result['objects'] = [pp_get_single_image(d) or d for d in result['objects']]

def pp_post_image_in(data=None, **kw):
    import base64
    data['image'] = base64.b64decode(data['image'])

def pp_post_image_out(result=None, **kw):
    import base64
    result['image'] = base64.b64encode(result['image']).decode('utf8')

postprocessors=dict(GET_SINGLE=[pp_get_single_image], GET_MANY=[pp_get_many_images], POST=[pp_post_image_out])
preprocessors=dict(POST=[pp_post_image_in])

manager = flask_restless.APIManager(app, flask_sqlalchemy_db=db)
manager.create_api(Image, methods=['GET', 'POST', 'DELETE'],
               postprocessors=pp_image.postprocessors,
               preprocessors=pp_image.preprocessors)
于 2018-10-11T22:08:58.633 回答