我正在使用Python、flaskrestfulw/pymongo为新的web服务构建API。在
一个示例MongoDB文档应该如下所示:
{ domain: 'foobar.com',
attributes: { web: [ akamai,
google-analytics,
drupal,
... ] } }
进口:
课程:
class AttributesAPI(Resource):
def __init__(self):
self.reqparse = reqparse.RequestParser()
self.reqparse.add_argument('domain', type = str, required = True, help = 'No domain given', location='json')
self.reqparse.add_argument('web', type = str, action='append', required = True, help = 'No array/list of web stuff given', location = 'json')
super(AttributesAPI, self).__init__()
def post(self):
args = self.reqparse.parse_args()
post = db.core.update( {'domain': args['domain']},
{'$set':{'attr': { 'web': args['web'] }}},
upsert=True)
return post
当我卷曲post时,我使用这个:
curl -i -H "Content-Type: application/json" -X POST -d '{"domain":"foobar", "web":"akamai", "web":"drupal", "web":"google-analytics"}' http://localhost:5000/v1/attributes
但是,这是保存在我的文档中的内容:
{ "_id" : ObjectId("5313a9006759a3e0af4e548a"), "attr" : { "web" : [ "google-analytics" ] }, "domain" : "foobar.com"}
它只存储“web”的curl中给出的最后一个值。我还尝试使用包含多个-d参数的CLI命令,如reqparse documentation中所述,但这抛出了一个400错误的请求错误。在
你知道为什么只保存最后一个值而不是将所有值保存为列表吗?在
在JSON对象和Python字典中,名称是唯一的;您不能在这里重复
web
键并期望它正常工作。使用一个web
键,并将该值列为一个列表:应该这样处理。在
除了@Martin Pieters的答案,您还需要将}的元组,
self.reqparse.add_argument
上的location
参数设置为json
和{store
参数是append
相关问题 更多 >
编程相关推荐