Heim >Backend-Entwicklung >PHP-Tutorial >Wie implementiert man die automatische Benutzerauthentifizierung nach der Registrierung in Symfony?

Wie implementiert man die automatische Benutzerauthentifizierung nach der Registrierung in Symfony?

Mary-Kate Olsen
Mary-Kate OlsenOriginal
2024-11-21 17:41:11716Durchsuche

How to Implement Automatic User Authentication After Registration in Symfony?

Automatische Benutzerauthentifizierung nach der Registrierung

Beim Erstellen einer Symfony 2-Geschäftsanwendung kommt es häufig vor, dass eine automatische Benutzerauthentifizierung erforderlich ist nach Anmeldung. So können Sie dies erreichen:

Symfony 4.0 und höher

Der Ansatz für die automatische Authentifizierung bleibt gegenüber früheren Versionen von Symfony unverändert. Hier ist ein Beispiel mit AbstractController:

use Symfony\Component\Security\Core\Authentication\Token\UsernamePasswordToken;
use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
use YourNameSpace\UserBundle\Entity\User;

class LoginController extends AbstractController
{
    public function registerAction()
    {
        $user = //Handle getting or creating the user entity likely with a posted form
        $token = new UsernamePasswordToken($user, null, 'main', $user->getRoles());
        $this->container->get('security.token_storage')->setToken($token);
        $this->container->get('session')->set('_security_main', serialize($token));
        // The user is now logged in, you can redirect or do whatever.
    }
}

Symfony 2.6.x - Symfony 3.0.x

In diesen Versionen ist security.context zugunsten der Sicherheit veraltet. token_storage. Hier ist der aktualisierte Controller:

use Symfony\Component\Security\Core\Authentication\Token\UsernamePasswordToken;
use Symfony\Bundle\FrameworkBundle\Controller\Controller;
use YourNameSpace\UserBundle\Entity\User;

class LoginController extends Controller
{
    public function registerAction()
    {
        $user = //Handle getting or creating the user entity likely with a posted form
        $token = new UsernamePasswordToken($user, null, 'main', $user->getRoles());
        $this->get('security.token_storage')->setToken($token);
        $this->get('session')->set('_security_main', serialize($token));
    }
}

Symfony 2.3.x

In dieser Version reicht es nicht aus, das Token im Sicherheitskontext festzulegen; Sie müssen es auch in der Sitzung speichern:

use Symfony\Component\Security\Core\Authentication\Token\UsernamePasswordToken;
use Symfony\Bundle\FrameworkBundle\Controller\Controller;
use YourNameSpace\UserBundle\Entity\User;

class LoginController extends Controller
{
    public function registerAction()
    {
        $user = //Handle getting or creating the user entity likely with a posted form
        $token = new UsernamePasswordToken($user, null, 'main', $user->getRoles());
        $this->get('security.context')->setToken($token);
        $this->get('session')->set('_security_main',serialize($token));
        //Now you can redirect where ever you need and the user will be logged in
    }
}

Denken Sie daran, UsernamePasswordToken mit den folgenden Parametern zu verwenden: Benutzerentität, Benutzeranmeldeinformationen (optional), Firewall-Name, Benutzerrollen.

Das obige ist der detaillierte Inhalt vonWie implementiert man die automatische Benutzerauthentifizierung nach der Registrierung in Symfony?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn