JWT Token декодирование - Symfony 4 - PullRequest
0 голосов
/ 07 февраля 2020

Я пытаюсь решить проблему, связанную с запросом токена. Это моя функция newArticle (чтобы добавить новую статью) в контроллере:

public function newArticle(Request $request, EntityManagerInterface $entityManager): View
    {
        $data = json_decode($request->getContent(), true);
        $title = $data['title'];
        $content = $data['content'];
        //$published_at = $data['published_at'];
        $authorizationHeader = $request->headers->get('Authorization');
        list(,$token) = explode(' ', $authorizationHeader);
        $jwtToken = $this->JWTEncoder->decode($token);
        $user_id = $data[$jwtToken];
        $userId = $this->userRepository->findOneBy(['id' => $user_id['id']]);
        $article = new Article();
        $article->setTitle($title);
        $article->setContent($content);
        $article->setPublishedAt(new \DateTime());
        $article->setUser($userId);
        // Todo: 400 response - Invalid input
        // Todo: 404 response - Response not found
        // Incase our Post was a success we need to return a 201 HTTP CREATED response with the created object
        if(in_array('ROLE_USER', $article->getUser()->getRoles(), true)) {
            $entityManager->persist($article);
            $entityManager->flush();
            return View::create("You added an article successfully!", Response::HTTP_OK);
        } else {
            return View::create(["You are not a user! So please register to add an article!"], Response::HTTP_BAD_REQUEST);
        }
    } 

Она работает до добавления авторизации заголовка токена, и теперь я получил эту ошибку:

"error": {
   "code": 500,
  "message": "Internal Server Error",
 "message": "Notice: Undefined offset: 1", 

Может кто-то дайте мне какие-либо предложения?

1 Ответ

0 голосов
/ 11 февраля 2020

Я думаю, что ваша проблема в этой строке:

$user_id = $data[$jwtToken];

Вы должны изменить ее, подумайте, что это должно быть что-то вроде:

$user_id = $data['user_id'];

или

$user_id = $jwtToken['user_id'];

В зависимости от того, какие данные содержат каждый объект / массив, где вы должны выглядеть. Во-первых, ошибка заключается в вызове смещения в массиве, поэтому исправление должно выполняться (или иметь более четкое сообщение об ошибке из журнала)

...