当预期为 405 时,服务器以状态代码 200 响应

Server responding with status code 200 when 405 was expected

我想了解为什么我会在此处收到 200 状态代码。我是 运行 一个烧瓶应用程序,在请求处理的端点而不是处理的方法时得到 200 状态代码作为响应。

这是最小的、可重现的代码。 app.py 文件:

from flask import Flask, request, abort, jsonify
from flask_sqlalchemy import SQLAlchemy
from sqlalchemy import Column, String, Integer

def create_app():
    db = SQLAlchemy()
    app = Flask(__name__)
    app.config["SQLALCHEMY_DATABASE_URI"] = "postgresql://postgres:postgres@localhost:5432/so_question"
    app.config["SQLALCHEMY_TRACK_MODIFICATIONS"] = False
    db = SQLAlchemy()
    db.app = app
    db.init_app(app)
    db.create_all()

    class Book(db.Model):  
        __tablename__ = 'books'

        id = Column(Integer, primary_key=True)

        def __init__(self, id):
            self.id = id

        def format(self):
            return {
            'id': self.id,
            }

    @app.route('/books')
    def get_books():
        books = Book.query.order_by(Book.id).all()
        return jsonify({
            'books': [book.format() for book in books],
        })

    @app.route('/books/<int:book_id>', methods=["PATCH"])
    def update_title(book_id):
        return jsonify({
            'success': True
        })

    @app.errorhandler(405)
    def not_allowed(error):
        return jsonify({
            "success": False,
        })
    
    return app

那我运行FLASK_APP=app.py flask run。 我提出了以下请求:curl -X GET http://127.0.0.1:5000/books 结果是这样的:

{
  "books": [
    {
      "id": 1
    }, 
    {
      "id": 2
    }
  ]
}

但这是我不明白的地方:我没有处理对 /books/<int:book_id 端点的 POST 请求,实际上如果我发出该请求:curl -X POST http://127.0.0.1:5000/books/2 404错误处理程序管理响应。我不明白的是为什么服务器响应 "POST /books/2 HTTP/1.1" 200 -。为什么这个错误的 200 状态代码实际上被检测为错误(因为响应正在由 405 错误处理程序处理)。?

我很确定答案与 有关,但我想问的是为什么会发生这种情况,而不是如何修复或什么应该是这个问题的最佳状态代码。

没有状态代码的返回将默认为代码 200

    def not_allowed(error):
        return jsonify({
            "success": False,
        })

这个函数应该return你想要的状态代码。

return jsonify({"success": False}), 405