使用flask-restless关系的POST请求错误

埃文·哈默(Evan Hammer)

我正在使用烧瓶不动,并且在我的第一个POST(来自Postman)中收到错误请求(400)错误。如果我继续提出相同的要求,则会不断出错。但是,如果我删除了flask-restless抱怨的字段,再次运行POST,获得肯定的响应,重新添加相同的字段,然后再次运行它,则此后就可以正常工作了。

网址: /api/appraisals

要求JSON:

{
    "suggested_price": 88,
    "listing": {"id": 1}
}

错误响应:

{
    "message": "Model does not have field 'listing'"
}

app.py:

from models.db import init_app
from controllers import api


app = Flask(__name__)
app.config.from_object('config')
init_app(app)

api.init_api(app)

来自models.db.py:

 from flask.ext.sqlalchemy import SQLAlchemy

 def init_app(app):
      with app.app_context():
           db.init_app(app)
           db.create_all()

 db = SQLAlchemy()

来自controllers.api.py:

 from flask.ext.restless import APIManager

 class ResourceManager(APIManager): ...

 def init_api(app):
      with app.app_context():
           manager = ResourceManager(app, flask_sqlalchemy_db=db)
           manager.add_resource(ListingResource())
           manager.add_resource(AppraisalResource())

来自models.appraisal.py:

 from .db import db
 from .base import BaseModel


 class Appraisal(BaseModel):

      __tablename__ = "appraisal"

      # required fields
      suggested_price = db.Column(db.Integer, nullable=False)

      # optional fields
      currency = db.Column(db.Unicode, default=u"USD")

      # relationships
      listing_id = db.Column(db.Integer, db.ForeignKey('listing.id'))

来自models.listing.py:

 from sqlalchemy.schema import UniqueConstraint

 from .db import db
 from .base import BaseModel

 class Listing(StatusfulModel, BaseModel):

     __tablename__ = "listing"

     # relationships
     appraisals = db.relationship(
         "Appraisal",
         backref=db.backref("listing", uselist=False),
         uselist=True)

来自controllers.resource.appraisal.py:

 class AppraisalResource(Resource):

      model_class = Appraisal
      base_url = "appraisals"
      allowed_methods = ["POST", "GET"]

      def get_fields(self):
           super_fields = super(AppraisalResource, self).get_fields()

           return super_fields + [
                "listing",
                "listing.id"
           ]
或段

我认为,解释如何解决此错误的最好方法是告诉您在考虑时我的想法。

您将通过API大量了解这些情况,并且知道如何考虑逻辑也很重要。

  1. 您收到错误400-这表示您发送的是JSON,但格式不是Flask预期的。
  2. 根据您的问题,删除列表字段可以解决问题-感觉我们越来越近了。
  3. 我查看了您尝试进行更改的模型(/api/appraisals)-评估
  4. 您的模型:

    class Appraisal(BaseModel):
        __tablename__ = "appraisal"
    
        suggested_price = db.Column(db.Integer, nullable=False)
        currency = db.Column(db.Unicode, default=u"USD")
        listing_id = db.Column(db.Integer, db.ForeignKey('listing.id'))
    
  5. 看完之后,您可以看到Flask期望“ listing_id”-而不是“ listing”

我希望我很清楚,告诉我您是否需要任何帮助。祝你好运!

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章