Heim >Backend-Entwicklung >PHP-Tutorial >Wie implementiert man die automatische Benutzerauthentifizierung nach der Registrierung 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!