gpt4 book ai didi

json - Flask 中的 RESTful 接口(interface)和序列化问题

转载 作者:行者123 更新时间:2023-12-03 15:50:10 29 4
gpt4 key购买 nike

我正在学习 Backbone.js 和 Flask(以及 Flask-sqlalchemy)。我之所以选择 Flask,是因为我读到它与实现 RESTful 接口(interface)的 Backbone 配合得很好。我目前正在关注 course使用(或多或少)这个模型:

class Tasks(db.Model):
id = db.Column(db.Integer, primary_key=True)
title = db.Column(db.String(80), unique=True)
completed = db.Column(db.Boolean, unique=False, default=False)

def __init__(self, title, completed):
self.title = title
self.completed = completed

def json_dump(self):
return dict(title=self.title, completed=self.completed)

def __repr__(self):
return '<Task %r>' % self.title

我必须添加一个 json_dump方法以便将 JSON 发送到浏览器。否则,我会收到像 object is not JSON serializable 这样的错误。 ,所以我的第一个问题是:

有没有更好的方法在 Flask 中进行序列化?似乎有些对象是可序列化的,而另一些则不是,但总的来说,它并不像我预期的那么容易。

一段时间后,我最终得到了以下 View 来处理每种类型的请求:
@app.route('/tasks')
def tasks():
tasks = Tasks.query.all()
serialized = json.dumps([c.json_dump() for c in tasks])
return serialized

@app.route('/tasks/<id>', methods=['GET'])
def get_task(id):
tasks = Tasks.query.get(int(id))
serialized = json.dumps(tasks.json_dump())
return serialized

@app.route('/tasks/<id>', methods=['PUT'])
def put_task(id):
task = Tasks.query.get(int(id))
task.title = request.json['title']
task.completed = request.json['completed']
db.session.add(task)
db.session.commit()
serialized = json.dumps(task.json_dump())
return serialized

@app.route('/tasks/<id>', methods=['DELETE'])
def delete_task(id):
task = Tasks.query.get(int(id))
db.session.delete(task)
db.session.commit()
serialized = json.dumps(task.json_dump())
return serialized

@app.route('/tasks', methods=['POST'])
def post_task():
task = Tasks(request.json['title'], request.json['completed'])
db.session.add(task)
db.session.commit()
serialized = json.dumps(task.json_dump())
return serialized

在我看来,这似乎有点冗长。同样,实现它们的正确方法是什么?我看过一些 extensions在 Flask 中提供 RESTful 接口(interface),但这些对我来说看起来相当复杂。

谢谢

最佳答案

老实说,我会使用一个模块来做到这一点。我们已经为一些 API 使用了 Flask-ReSTLess,你可以看看:

https://flask-restless.readthedocs.org/en/latest/

但是,如果您想构建自己的,您可以使用 SQLAlchemy 的自省(introspection)将您的对象输出为键/值对。

http://docs.sqlalchemy.org/en/rel_0_7/core/schema.html#metadata-reflection

像这样的东西,虽然我总是要反复检查我的语法是否正确,所以把它作为指导而不是工作代码。

@app.route('/tasks')
def tasks():
tasks = Tasks.query.all()

output = []
for task in tasks:
row = {}

for field in Tasks.__table__.c:
row[str(field)] = getattr(task, field, None)

output.append(row)

return jsonify(data=output)

我发现这个问题可能对你有更多帮助。我熟悉 SQLAlchemy 0.7,看起来 0.8 添加了一些更好的内省(introspection)技术:

SQLAlchemy introspection

关于json - Flask 中的 RESTful 接口(interface)和序列化问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13539082/

29 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com