我有一个在Flask中的sqlite数据库中的db.model。它看起来像这样:
class Drink(db.Model):
id = db.Column(db.Integer, primary_key = True)
name = db.Column(db.String(64), index = True)
kind = db.Column(db.String(64), index = True)
image = db.Column(db.LargeBinary)
def __init__(self, name, kind, image):
self.name = name
self.kind = kind
self.image = image
def __repr__(self):
return '<Drink %r>' % self.name
那么,我的问题是我有这个列名为“image”的列,它将是一张实际的图片,但我不知道在Flask代码中使用什么数据类型。
以下是Flask代码:Flask
class DrinkAPI(Resource):
def __init__(self):
self.reqparse = reqparse.RequestParser()
self.reqparse.add_argument('name', type = str, required = True, help = 'No name title provided', location = 'json')
self.reqparse.add_argument('type', type = str, required = True, help='No type provided', location = 'json')
self.reqparse.add_argument('image', type = blob, required = True, help='No image provided', location = 'json')
super(DrinkAPI, self).__init__()
def get(self, id):
if checkDrink(id):
info = getDrinkInfo(id)
return {'id': id, 'name': info[0], 'type':info[1], 'image': info[2]}
abort(404)
def put(self, id):
if checkDrink(id):
args = self.reqparse.parse_args()
deleteDrink(id)
drink = Drink(args['name'], args['type'], args['image'])
addDrink(drink)
return {'drink' : marshal(drink, drink_fields)}, 201
abort(404)
def delete(self, id):
deleteDrink(id)
return { 'result': True}
看到我将
reqparse
的类型设置为blob
吗?这甚至不是一个实际的数据类型,但我不知道应该放什么。我需要子类化fields.Raw
吗?有什么想法吗?谢谢。
问题的新方法 根据一些评论,似乎我应该将图像存储在我的静态文件夹中。我可以这样做。但是,如何引用它与我的数据库?它是对应于
.jpg
文件的字符串吗?