我设法弄清楚如何使用curl从帮助中将信息发布到数据库但是我的实际代码有问题,我不知道如何解决它。在我的POST方法中,当我尝试从我的类中请求json信息时,它在我使用curl时不起作用并且它说。错误在行
中dev = Todo(request.json.details)
AttributeError: 'dict' object has no attribute 'details'
我正在尝试将todo_ID,UserID,详细信息添加到数据库中的Todo表中。由于错误,我无法发布任何内容,每当我尝试将todo_ID或CustID放入时,我也会收到相同的错误消息。
我把我想要使用的信息放在json文件中。看起来像这样。
{
"todo_ID": 13,
"UserID": 8,
"details": "Clean up your room."
}
这是我的代码。
from flask import Flask, jsonify,json, request, abort
from flask_sqlalchemy import SQLAlchemy
import requests
app = Flask(__name__)
app.config.from_pyfile('Config.py')
db = SQLAlchemy(app)
class JsonModel(object):
def as_dict(self):
return {c.name: getattr(self, c.name) for c in self.__table__.columns}
class User(db.Model, JsonModel):
User_ID = db.Column(db.Integer, primary_key = True)
FirstName = db.Column(db.String(20))
LastName = db.Column(db.String(20))
def __init__(self,FirstName, LastName):
self.FirstName = FirstName
self.LastName = LastName
class Todo(db.Model, JsonModel):
todo_ID = db.Column(db.Integer, primary_key = True)
UserID = db.Column(db.Integer, db.ForeignKey('User_ID'))
details = db.Column(db.String(30))
def __init__(self,details):
self.details = details
app.route('/', methods = ['GET'])
def index():
return json.dumps([u.as_dict() for u in User.query.all()+Todo.query.all()])
@app.route('/', methods = ['POST'])
def create_dev():
dev = Todo(request.json.details)
db.session.add(dev)
db.session.commit()
return json.dumps([{'dev': dev}]), 201
@app.before_first_request
def startup():
db.create_all()
if __name__ == '__main__':
app.run()
答案 0 :(得分:0)
Python不是JavaScript。而不是
dev = Todo(request.json.details)
试试这个:
dev = Todo(request.json["details"])