- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用 flask 构建一个 REST API。我正在使用 postman 测试在我的数据库中创建新项目的路线,但前提是用户已登录。注册和登录的路线运行良好,最后一个使用 flask_jwt_extended 模块返回 token 。当我向我的“/api/notes”(在数据库中创建一个新注释)发送一个发布请求时,我收到以下错误:
"(...) raise TypeError(f'Object of type {o. class . name } '
TypeError:类型函数的对象不是 JSON 可序列化的“
对于我正在使用 postman 的授权选项卡的请求。 type:Bearer Token,字段中我的token(带引号和不带引号都试过)
我今天早上遇到了这个错误,在实现我的一对多关系之前,但我通过在 Barear token 字段中用“VERY_LONG_TOKEN”替换我的 VERY_LONG_TOKEN 来让它工作。我认为因为 token 包含点,所以它被解释为一个函数。但是在实现了关系之后,我去测试,又得到了这个错误。
我的 note.py 文件:
from flask import request, Response, jsonify
from app.models import User, Note
from flask_restful import Resource
from flask_jwt_extended import jwt_required, get_jwt_identity
class NotesApi(Resource):
def get(self):
notes = Note.objects().to_json()
return Response(notes, mimetype="application/json", status=200)
@jwt_required
def post(self): # post method I'm making a request for
print("fool") # this doesn't get printed -> not reaching
user_id = get_jwt_identity()
data = request.get_json(force=True)
if data:
user = User.objects(id=user_id) # logged in user
note = Note(**data, user_author=user) # creates note with the author
note.save()
user.update(push__notes=note) # add this note to users notes
user.save()
id = str(note.id)
return {'id': id}, 200
else:
return {'error': 'missing data'}, 400
我的模型.py:
from app import db # using mongodb
from datetime import datetime
from flask_bcrypt import generate_password_hash, check_password_hash
class Note(db.Document):
title = db.StringField(max_length=120,required=True)
content = db.StringField(required=True)
status = db.BooleanField(required=True, default=False)
date_modified = db.DateTimeField(default=datetime.utcnow)
user_author = db.ReferenceField('User')
class User(db.Document):
username = db.StringField(max_length=100, required=True, unique=True)
email = db.StringField(max_length=120, required=True, unique=True)
password = db.StringField(required=True)
remember_me = db.BooleanField(default=False)
notes = db.ListField(db.ReferenceField('Note', reverse_delete_rule=db.PULL)) # one-many relationship
def hash_password(self):
self.password = generate_password_hash(self.password).decode('utf8')
def check_password(self, password):
return check_password_hash(self.password, password)
User.register_delete_rule(Note, 'user_author', db.CASCADE)
初始化 .py:
from flask import Flask
from config import Config # my config class to set MONGOBD_HOST and SECRET_CLASS
from flask_mongoengine import MongoEngine
from flask_restful import Api
from flask_bcrypt import Bcrypt
from flask_jwt_extended import JWTManager
app = Flask(__name__)
app.config.from_object(Config)
db = MongoEngine(app)
api = Api(app)
bcrypt = Bcrypt(app)
jwt = JWTManager(app)
from app.resources.routes import initialize_routes
initialize_routes(api)
资源/routes.py:
from .note import NotesApi, NoteApi
from .auth import SignupApi, LoginApi
def initialize_routes(api):
api.add_resource(NotesApi, '/api/notes')
api.add_resource(NoteApi, '/api/note/<id>')
api.add_resource(SignupApi, '/api/auth/signup')
api.add_resource(LoginApi, '/api/auth/login')
文件夹结构:
app
|_ resources
|_ auth.py # signup working well, login also working, return a token (type = String)
|_ note.py
|_ routes.py
|_ __init__.py
|_ models.py
config.py
appname.py #just import app and do a app.run()
我的帖子请求的正文:
{
"title": "test0",
"content": "test0"
}
有没有人遇到过或知道如何解决它?
最佳答案
看起来flask-jwt-extended 在周末发布了一个新版本。作为 API 更改的一部分,@jwt_required
装饰师现在是 @jwt_required()
https://flask-jwt-extended.readthedocs.io/en/stable/v4_upgrade_guide/#api-changes
关于python - 类型错误 : Object of type function is not JSON serializable when using flask_jwt_extended int RESTful API,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/66200136/
再次尝试制作我的第一个 Flask 应用程序,这一次,(在我创建了我需要的每一个并且一切顺利之后)我试图用 flask_jwt_extended 保护一些端点,但我不能'在我的页面中找不到如何使用它们
我在尝试在我的应用程序中捕获格式错误的 JWT 错误时遇到问题。 我正在使用 flask_jwt_extended 并且当我发送手动创建的 JWT 时。我收到此错误消息: Error on reque
我想在调用@jwt_required 时向 token 添加额外的验证。我想验证其中一项声明。我可以用 JWTManager 做到这一点吗? 目前我的代码只调用: jwt = JWTManager(a
在 localhost:5000 脚本正在运行,没有任何错误。但是当涉及到符号链接(symbolic link)时,appache 日志中会出现错误。 [Sun Jun 10 17:07:16.170
我正在使用 flask 构建一个 REST API。我正在使用 postman 测试在我的数据库中创建新项目的路线,但前提是用户已登录。注册和登录的路线运行良好,最后一个使用 flask_jwt_ex
我在 Flask 应用程序中遇到了这个错误: curl http://0.0.0.0:8080/ -H "Authorization: Bearer TGazPL9rf3aIftplCYDTGDc8c
我是一名优秀的程序员,十分优秀!