Heim  >  Artikel  >  Backend-Entwicklung  >  So implementieren Sie in PHP, dass sich nur eine Person bei einem Konto anmelden kann

So implementieren Sie in PHP, dass sich nur eine Person bei einem Konto anmelden kann

藏色散人
藏色散人Original
2021-03-12 10:55:032935Durchsuche

php-Methode, um zu erkennen, dass sich nur eine Person bei einem Konto anmelden kann: 1. Speichern Sie die Sitzungsinformationen in Redis. 2. Speichern Sie die Sitzungs-ID in der MySQL-Datenbank. 3. Wenn Sie sich anmelden, überprüfen Sie den Benutzernamen und das Kennwort. Die Benutzerinformationen werden gespeichert. Lesen Sie die Datenbank, rufen Sie die Sitzungs-ID ab und überprüfen Sie, ob die Sitzung abgelaufen ist. 4. Wenn sie nicht abgelaufen ist, übertragen Sie die Nachricht mit OpenFire. 5. Aktualisieren Sie die neue Sitzungs-ID.

So implementieren Sie in PHP, dass sich nur eine Person bei einem Konto anmelden kann

Die Betriebsumgebung dieses Artikels: Windows7-System, PHP8-Version, DELL G3-Computer

php erkennt, dass sich nur eine Person gleichzeitig bei demselben Konto anmelden kann

Ich habe über dieses Problem nachgedacht Früher und heute implementiert, ist es ziemlich schnell, es dauert fast 4 Stunden von der Forschung bis zur Entwicklung. Es ist ein bisschen wie bei QQ. Wenn Sie sich mit zwei Computern anmelden, verdrängt einer den anderen und fordert Sie auf, Anmeldeinformationen von anderen Standorten einzugeben.

1. Implementierungsprinzip

1 Der Benutzer meldet sich auf Computer A an, die Sitzungsinformationen werden in Redis gespeichert und die Sitzungs-ID wird in der MySQL-Datenbank gespeichert.

2. Derselbe Benutzer meldet sich auf Computer B an. Nachdem Sie den Benutzernamen und das Kennwort überprüft haben, lesen Sie die Benutzerinformationen aus der Datenbank, rufen Sie die Sitzungs-ID des auf Computer A angemeldeten Benutzers ab und überprüfen Sie dann, ob die Sitzung abgelaufen ist redis.

3. Wenn es abläuft, besteht keine Notwendigkeit, Openfire zum Übertragen von Eingabeaufforderungsinformationen zu verwenden. Wenn es nicht abgelaufen ist, löschen Sie die Sitzung in Redis, in der sich der Benutzer auf Computer A angemeldet hat, nachdem PHP Openfire zum Senden der Nachricht verwendet hat. Fügen Sie nach dem Löschen die persönlichen Daten des auf Computer B angemeldeten Benutzers in die Sitzung ein und fügen Sie sie ein Die persönlichen Daten des auf Computer B angemeldeten Benutzers werden in die Sitzung eingefügt und die Sitzung gelöscht, in der sich der Benutzer auf Computer B angemeldet hat. Die Sitzungs-ID wird in der Datenbank aktualisiert. Hier muss zuerst der Push gesendet und dann die Sitzung gelöscht werden. Der Benutzer auf Computer A erhält die von xmpp gesendete Nachricht nicht.

Hinweis:

openfire ist eine Art Java-CMS und verfügt über eine eigene Datenbank. Die von Ihnen erstellte Benutzertabelle muss eine Verbindung (z. B. Mobiltelefonnummer, E-Mail-Adresse usw.) zwischen den mitgelieferten Benutzertabellen herstellen Openfire, um den Informationsschub zu erleichtern.

Die gleiche Sitzungs-ID muss auf demselben Medium angemeldet sein. Zu diesem Zeitpunkt ist es nicht erforderlich, die Datenbank und Push-Nachrichten zu aktualisieren.

Das Folgende ist eine kurze Einführung in den Installationsprozess und was zu beachten ist.

Zweitens installieren Sie die verwendeten Tools

# yum install php php-fpm nginx mysql mysql-server redis php-redis php-devel php-pdo php-mysql

Ändern Sie die Sitzungsspeichermethode:

Anzeigen, Kopieren und Drucken?

# vim /etc/php-fpm.d/www.conf     
  
;php_value[session.save_handler] = files   //注释掉旧的  
;php_value[session.save_path] = /var/lib/php/session  
  
php_value[session.save_handler] = redis  //添加以下内容  
php_value[session.save_path] = "tcp://127.0.0.1:6379"

Wenn nach dem Starten des Dienstes der folgende Inhalt zeigt, dass die Sitzung erfolgreich in Redis gespeichert wurde

So implementieren Sie in PHP, dass sich nur eine Person bei einem Konto anmelden kann

redis telnet, um die Sitzung anzuzeigen

Openfire-Download-Adresse: http://www.igniterealtime.org/downloads/

Kopieren und drucken anzeigen?

# rpm -ivh ./*.rpm   //下载的是rpm安装包

Nachdem Openfire gestartet ist, besuchen Sie http://ip:9090 und konfigurieren Sie es Schritt für Schritt gibt es eine Sache. Beachten Sie, dass es sich um die Codierung der Datenbank handelt.

【Empfohlenes Lernen: „PHP-Video-Tutorial“】

Das obige ist der detaillierte Inhalt vonSo implementieren Sie in PHP, dass sich nur eine Person bei einem Konto anmelden kann. 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