Ошибка токена JWT: вход должен быть действительной строкойPython

Программы на Python
Ответить Пред. темаСлед. тема
Anonymous
 Ошибка токена JWT: вход должен быть действительной строкой

Сообщение Anonymous »

Я пытаюсь следовать учебному пособию Санджива по разработке Python API ( 1). До 7,5 часов у меня не было никаких проблем, но теперь я пытаюсь создать новый пост в почтальоне, используя токен JWT в качестве аутентификации. When I try to do this, I get this error:
“pydantic_core._pydantic_core.ValidationError: 1 validation error for TokenData
id
Input should be a valid string [type=string_type, input_value=14, input_type=int]”
I'm pretty sure I've followed along with the tutorial И что токен - это строка, поэтому я не знаю, где он идет не так. Я постараюсь предоставить весь соответствующий код, но если вы что -то упускаете, пожалуйста, дайте мне знать.

Код: Выделить всё

class TokenData(BaseModel):
id: Optional[str]
< /code>
от oauth2.py:
from jose import JWTError, jwt
from datetime import datetime, timedelta
from . import schemas
from fastapi import Depends, status, HTTPException
from fastapi.security import OAuth2PasswordBearer

oauth2_scheme = OAuth2PasswordBearer(tokenUrl='login')

SECRET_KEY = "b8b33abbff04e43b4a43aed2ab1cc44e962d236caee378dcccce9dc46a3a5592"
ALGORITHM = "HS256"
ACCESS_TOKEN_EXPIRE_MINUTES = 30

def create_access_token(data: dict):
to_encode = data.copy()
expire = datetime.utcnow() + timedelta(minutes=ACCESS_TOKEN_EXPIRE_MINUTES)
to_encode.update({"exp": expire})
encoded_jwt = jwt.encode(to_encode, SECRET_KEY, algorithm=ALGORITHM)

return encoded_jwt

def verify_access_token(token: str, credentials_exception):
try:
payload = jwt.decode(token, SECRET_KEY, algorithms=[ALGORITHM])
id: str = payload.get("user_id")
if id is None:
raise credentials_exception
token_data = schemas.TokenData(id=id)

except JWTError:
raise credentials_exception

return token_data

def get_current_user(token: str = Depends(oauth2_scheme)):
credentials_exception = HTTPException(status_code=status.HTTP_401_UNAUTHORIZED, detail=f'Could not validate credentials', headers={'WWW-Authenticate': 'bearer'})
return verify_access_token(token, credentials_exception)
< /code>
из post.py:
@router.post("/", status_code=status.HTTP_201_CREATED, response_model=schemas.Post)
def create_post(post: schemas.PostCreate, db: Session = Depends(get_db), user_id: int = Depends(oauth2.get_current_user)):
print(user_id)
new_post = models.Post(**post.model_dump())
db.add(new_post)
db.commit()
db.refresh(new_post)
return new_post
Я пытался добавить ': str' за несколькими значениями, но это не меняет результат.

Подробнее здесь: https://stackoverflow.com/questions/782 ... lid-string
Реклама
Ответить Пред. темаСлед. тема

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

  • Похожие темы
    Ответы
    Просмотры
    Последнее сообщение
  • Pydantic «Вход должен быть действительной строкой» при строительстве с словарем
    Anonymous » » в форуме Python
    0 Ответы
    8 Просмотры
    Последнее сообщение Anonymous
  • Вход не является действительной строкой Base64, поскольку он содержит символ не-базовой 64
    Anonymous » » в форуме C#
    0 Ответы
    12 Просмотры
    Последнее сообщение Anonymous
  • Ошибка токена JWT: ввод должен быть допустимой строкой
    Anonymous » » в форуме Python
    0 Ответы
    19 Просмотры
    Последнее сообщение Anonymous
  • Несанкционированная ошибка токена веб-API JWT, несмотря на передачу токена в заголовке авторизации
    Anonymous » » в форуме C#
    0 Ответы
    65 Просмотры
    Последнее сообщение Anonymous
  • Laravel не проверяет подлинность токена JWT Tymon/jwt-auth
    Anonymous » » в форуме Php
    0 Ответы
    26 Просмотры
    Последнее сообщение Anonymous

Вернуться в «Python»