Python、Bottle、MongoDB 创建函数 500 错误代码

Python, Bottle, MongoDB Create Function 500 Error Code

我正在使用 Bottle 和 MongoDB 创建 REST 服务。问题是我在尝试插入文档时收到 500 错误代码。

<!DOCTYPE HTML PUBLIC "-//IETF//DTD HTML 2.0//EN">
    <html>
        <head>
            <title>Error: 500 Internal Server Error</title>
            <style type="text/css">
              html {background-color: #eee; font-family: sans;}
              body {background-color: #fff; border: 1px solid #ddd;
                    padding: 15px; margin: 15px;}
              pre {background-color: #eee; border: 1px solid #ddd; padding: 5px;}
            </style>
        </head>
        <body>
            <h1>Error: 500 Internal Server Error</h1>
            <p>Sorry, the requested URL <tt>&#039;http://localhost:8080/create&#039;</tt>
               caused an error:</p>
            <pre>Unhandled exception</pre>
        </body>
    </html>

cURL

curl -H "Content-Type: application/json" -X POST -d '{"id" : "10011-2017-TEST","certificate_number" : 9278833,"business_name" : "ACME TEST INC.","date" : "Feb 20 2017","result" : "No Violation Issued","sector" : "Test Retail Dealer - 101"}' http://localhost:8080/create

尽管如此,即使收到 500 错误代码,我也能够成功插入文档。为什么我会收到 500 错误代码?我一直在尝试为 MongoDB 和 Bottle 实现异常处理。不确定这是否是我获取代码的原因。如果没有,我该如何正确实施异常处理?我已经阅读了有关中止的内容,但是我遇到了麻烦。另外,当我注释掉 return result 时,我得到一个 200 响应代码,但我想 return 插入文档的 ID。谢谢

源代码:

#!/usr/bin/python
# -*- coding: utf-8 -*-
from bson import json_util
import json
import bottle
from bottle import route, run, request, abort, post, error
import pymongo
from pymongo import MongoClient
import datetime as datetime

connection = MongoClient('localhost', 27017)
db = connection['city']
collection = db['inspections']


@route('/create', method='POST')
def insert_document():

    try:
        data = request.json
        result = collection.insert_one(data).inserted_id
    except Exception, e:

        print ('EXCEPTION: ', e)

    return result

if __name__ == '__main__':

    run(host='localhost', port=8080)

改变

    return result

    return str(result)

或者完全删除该行。