Здравствуйте, я разрабатываю приложение под sf4 для части API + VueJS для фронтальной и докерской части. У меня проблема с созданием пользователя из моей модели USER.
Вот ошибка, которая возникает при создании пользователя:
{
«код»: 401,
"message": "токен JWT не найден"
}
Я посмотрел на свои ключи, если она была правильно настроена. У меня есть свой закрытый ключ:
мои 2 ключа находятся в config / jwt
----- BEGIN RSA ЧАСТНЫЙ КЛЮЧ -----
Proc-Type: 4, ENCRYPTED ----- END RSA ЧАСТНЫЙ КЛЮЧ -----
Мой открытый ключ:
----- НАЧАТЬ ПУБЛИЧНЫЙ КЛЮЧ ----- ----- КОНЕЦ ПУБЛИЧНОГО КЛЮЧА -----
Мой .env:
JWT_SECRET_KEY = конфигурации / JWT / private.pem
JWT_PUBLIC_KEY = конфигурации / JWT / public.pem
JWT_PASSPHRASE = my_pass_phrase
Моя сущность Пользователь:
<?php
namespace App\User\Entity;
use ApiPlatform\Core\Annotation\ApiResource;
use Doctrine\ORM\Mapping as ORM;
use Symfony\Component\Security\Core\User\UserInterface;
/**
* @ORM\Entity(repositoryClass="App\User\Repository\UserRepository")
* @ApiResource()
*/
class User implements UserInterface, \Serializable
{
/**
* @ORM\Id
* @ORM\GeneratedValue
* @ORM\Column(type="integer")
*/
private $id;
/**
* @ORM\Column(type="string", length=25, unique=true)
*/
private $username;
/**
* @ORM\Column(type="string", length=64)
*/
private $password;
/**
* @ORM\Column(type="string", length=60, unique=true)
*/
private $email;
/**
* @ORM\Column(name="is_active", type="boolean")
*/
private $isActive;
private $plainPassword;
public function __construct()
{
$this->isActive = true;
// may not be needed, see section on salt below
// $this->salt = md5(uniqid('', true));
}
/**
* @return mixed
*/
public function getId()
{
return $this->id;
}
/**
* @return mixed
*/
public function getIsActive()
{
return $this->isActive;
}
public function getUsername()
{
return $this->username;
}
public function getSalt()
{
// you *may* need a real salt depending on your encoder
// see section on salt below
return null;
}
public function getPassword()
{
return $this->password;
}
public function getRoles()
{
return array('ROLE_USER');
}
public function eraseCredentials()
{
}
public function toArray(): array
{
return [
'username' => $this->username,
'email' => $this->email,
'isActive' => $this->isActive,
'roles' => [
'IS_AUTHENTICATED_FULLY',
],
];
}
/**
* @param mixed $username
*/
public function setUsername($username): void
{
$this->username = $username;
}
/**
* @param mixed $password
*/
public function setPassword($password): void
{
$this->password = $password;
}
/**
* @return mixed
*/
public function getPlainPassword()
{
return $this->plainPassword;
}
/**
* @param mixed $plainPassword
*/
public function setPlainPassword($plainPassword)
{
$this->plainPassword = $plainPassword;
$this->password = null;
}
/**
* @param mixed $email
*/
public function setEmail($email): void
{
$this->email = $email;
}
/**
* @param mixed $isActive
*/
public function setIsActive($isActive): void
{
$this->isActive = $isActive;
}
/** @see \Serializable::serialize() */
public function serialize()
{
return serialize(array(
$this->id,
$this->username,
$this->password,
// see section on salt below
// $this->salt,
));
}
/** @see \Serializable::unserialize() */
public function unserialize($serialized)
{
list (
$this->id,
$this->username,
$this->password,
// see section on salt below
// $this->salt
) = unserialize($serialized);
}
/**
* @return mixed
*/
public function getEmail()
{
return $this->email;
}
}
Мой security.yml:
security:
# https://symfony.com/doc/current/security.html#where-do-users-come-from-user-providers
encoders:
App\User\Entity\User:
algorithm: bcrypt
providers:
our_db_provider:
entity:
class: App\User\Entity\User
property: username
firewalls:
login:
pattern: ^/api/login
stateless: true
anonymous: true
json_login:
check_path: /api/login_check
success_handler: lexik_jwt_authentication.handler.authentication_success
failure_handler: lexik_jwt_authentication.handler.authentication_failure
require_previous_session: false
api:
pattern: ^/api
stateless: true
guard:
authenticators:
- lexik_jwt_authentication.jwt_token_authenticator
dev:
pattern: ^/(_(profiler|wdt)|css|images|js)/
security: false
main:
anonymous: ~
# activate different ways to authenticate
# http_basic: ~
# https://symfony.com/doc/current/security.html#a-configuring-how-your-users-will-authenticate
# form_login: ~
# https://symfony.com/doc/current/security/form_login_setup.html
access_control:
- { path: ^/api/login, roles: IS_AUTHENTICATED_ANONYMOUSLY }
- { path: ^/api, roles: IS_AUTHENTICATED_FULLY }
Я не понимаю, в чем застряла ошибка, все та же ....
Спасибо за вашу помощь.