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
Freigeben: 2024-11-21 17:41:11
Original
735 Leute haben es durchsucht

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.
    }
}
Nach dem Login kopieren

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));
    }
}
Nach dem Login kopieren

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
    }
}
Nach dem Login kopieren

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!

Erklärung dieser Website
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
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage