«Не найдена активная учетная запись с данными учетными данными» в django-rest-framework-simple-jwt - PullRequest
0 голосов
/ 09 ноября 2019

Я не могу открыть jwt с помощью django-rest-framework-jwt. После того, как я выполнил запрос с помощью jwt-opeding-url, он сказал: «Не найдена активная учетная запись с указанными учетными данными», хотя указанная информация (адрес электронной почты, пароль) верна.

Я думаю, что создал пользователя с сериализатором неправильно. но не могу придумать какой-либо новый способ.

вид входа

@csrf_exempt
def facebook_login(request):
    body = dict(request.GET)
    code = body['code'][0]

    params_access = {
        "client_id": FACEBOOK_APP_ID,
        "redirect_uri": FACEBOOK_REDIRECT_URI,
        "client_secret": FACEBOOK_SECRET,
        "code": code
    }
    tokens = requests.get("https://graph.facebook.com/v5.0/oauth/access_token", params=params_access).json()
    access_token = tokens['access_token']

    params_debug = {
        "input_token": access_token,
        "access_token": f'{FACEBOOK_APP_ID}|{FACEBOOK_SECRET}'
    }
    debug = requests.get("https://graph.facebook.com/debug_token", params=params_debug).json()

    params_user = {
        "fields": ["email"],
        "access_token": access_token
    }
    user_fb_data = requests.get("https://graph.facebook.com/me", params=params_user).json()
    user_email = user_fb_data['email']

    user = User.objects.filter(email=user_email)
    if not user:
        user_data = {
            'email': user_email,
            'username': user_email,
        }
        user = UserSerializer(data=user_data, partial=True)
        if user.is_valid():
            user.save()
            print("saved!!!!!!!!!!!!!!!")
        else:
            print("error", user.errors)

    jwt_data = {
        'email': user_email,
        'password': access_token
    }
    jwt = requests.post(JWT_OPTAIN_URL, data=jwt_data).json()
    access_token = jwt['access']
    refresh_token = jwt['refresh']
    data = {
        'access_token': access_token,
        'refresh_token': refresh_token
    }
    return Response(data, status=status.HTTP_201_CREATED)

Сериализатор

class UserSerializer(serializers.ModelSerializer):
    def create(self, validated_data):
        user = super().create(validated_data)
        user.set_password(self)
        user.save()
        return user

    class Meta:
        model = User
        fields = ('email', 'username', 'refreshToken', 'password')
        extra_kwargs = {'password': {'write_only': True}}

Я предполагаю, что jwt создан с информацией электронной почты и паролем.

...