php判断在线用户实例详解
怎么才能准确的判断用户是否在线呢?下面小编就来给大家分享一个实例。
解决了昨天的问题:表结果变了一下,如下:
CREATE TABLE TB_User ( --用户表 N_UserId Number(5) NOT NULL, --用户ID V_NickName VARCHAR2(10) NOT NULL, --昵 称 V_PWD VARCHAR2(10) NOT NULL, --密 码 V_TrueName VARCHAR2(20), --姓 名 Primary Key (N_UserId) ) CREATE TABLE TB_OnlineUser ( --在线用户 N_OnlineUserId Number(5) NOT NULL, --在线用户ID D_LoginTime Number (16), --登陆时间以秒计 N_OnlineID Number(5), --与onlineusercount相关联。 Primary Key (N_OnlineID) ) / CREATE TABLE TB_OnlineUserCount ( --在线用户统计表 N_OnlineID Number(5) NOT NULL, --系统ID号 N_OnlineUserId Number(5) NOT NULL, --在线用户ID D_LoginDate Date , --登陆日期 D_LoginTime Number (16) , --登陆时间以秒计 D_OverDate Date , --结束日期 D_OverTime Number (16) , --结束时间 Primary Key (N_OnlineID) ) / /*---LoginselectNew.php---该程序是登陆检查程序----*/ <? session_start();
/*思路:首先用户登陆,判断是否有该用户,判断是否密码通过,否则返回参数进行特殊处理。(登陆不成功)
登陆成功后,如果该用户不在线(一般不在线,特殊情况如果他用另一台机器打开浏览器重新再登陆,那么他有可能在线),
先进行session变量注册,取得相应条件向1.统计表与2.在线表中插数据。进入到登陆页。
如果用户在线:先取得在线用户的系统ID,因为在备份该用户离开时有用。接着删除该在线用户.接着进行该用户离开时间的备份.
*/
session_register("objsNickName"); require('oracle8conn.php'); $name=trim($name); $pwd=trim($pwd); ob_start(); //缓冲输出 $stmtNick = OCIParse($conn,"select count(*) countnickname from tb_user where v_nickname='$name'"); OCIExecute($stmtNick); while(OCIFetchInto($stmtNick,&$arrN)){ if ($arrN[0]==0){ Header("Location:Logintest.php?Msg=1"); }else{ //用户名通过 unset($arrNickName); //撤消临时数组 $stmtPwd = OCIParse($conn,"select count(*) countpwd from tb_user where v_pwd='$pwd' and v_nickname='$name'"); OCIExecute($stmtPwd); while(OCIFetchInto($stmtPwd,&$arrP,OCI_NUM)){ if ($arrP[0]==0){ Header("Location:Logintest.php?Msg=2"); }else{//密码通过 //取出用户的ID号 $stmtUid = OCIParse($conn,"select n_userID from tb_user where v_nickname='$name'"); OCIExecute($stmtUid); while(OCIFetchInto($stmtUid,&$arrU,OCI_NUM)){ $intOnlineUserID=$arrU[0]; }//while_Over //如果该用户通过另一个浏览器重复登陆,解决如下 $stmOnlineFlag=OCIParse($conn,"select count(*) from tb_onlineuser where N_ONLINEUSERID='$intOnlineUserID'"); OCIExecute($stmOnlineFlag); while(OCIFetchInto($stmOnlineFlag,&$arronlineFlag,OCI_NUM)){ if ($arronlineFlag[0]!=0){ //表示已经在线 //先取到在线用户关联系统ID $stmtSysID= OCIParse($conn,"select N_ONLINEID from tb_onlineuser where N_ONLINEUSERID='$intOnlineUserID'"); OCIExecute($stmtSysID); while(OCIFetchInto($stmtSysID,&$arrSysID,OCI_NUM)){ $SysID=$arrSysID[0]; }//while_Over //找完后踢出该用户 $stmt = OCIParse($conn, "delete from tb_onlineuser where N_ONLINEUSERID='$intOnlineUserID'"); OCIExecute($stmt); print "删除成功"; //最后作记录备份 $tmpTime=time(); //结束时间 $DatLoginDate = date( "Y-m-d");//结束日期 $DatLoginDate = "to_date('".$DatLoginDate."','YY/MM/DD')"; $stmtUserCount = OCIParse($conn, "update tb_onlineusercount set D_OverDate=$DatLoginDate ,D_OverTime=$tmpTime where N_OnlineID='$SysID'");//条件是相关联的系统ID OCIExecute($stmtUserCount); print "添加成功到统计表中。"; }//endif //不在线正常注册 $objsNickName=$name; //注册Session变量 unset($arrPwd); //撤消临时数组 srand((double)microtime()*1000000000); $intOnlineID = rand(); //取一个系统ID号 $DatLoginDate = date( "Y-m-d"); //取得系统日期存入到Online表中去。 $DatLogintime = time(); //取系统时间 $DatLoginDate = "to_date('".$DatLoginDate."','YY/MM/DD')"; $stmt = OCIParse($conn, "insert into tb_onlineuser (N_OnlineUserId,D_LoginTime,N_OnlineID) values ($intOnlineUserID,$DatLogintime,$intOnlineID)"); OCIExecute($stmt); $stmtC = OCIParse($conn, "insert into TB_OnlineUserCount (N_OnlineID,N_OnlineUserId,D_LoginDate,D_LoginTime) values ($intOnlineID,$intOnlineUserID,$DatLoginDate,$DatLogintime)"); OCIExecute($stmtC); Header("Location:index.php"); //成功登陆! }//whileOVER }//end if }//while_Over }//end if }//while_Over ?>

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen

Mit der rasanten Entwicklung der sozialen Medien hat sich Xiaohongshu zu einer der beliebtesten sozialen Plattformen entwickelt. Benutzer können ein Xiaohongshu-Konto erstellen, um ihre persönliche Identität zu zeigen und mit anderen Benutzern zu kommunizieren und zu interagieren. Wenn Sie die Xiaohongshu-Nummer eines Benutzers finden müssen, können Sie diese einfachen Schritte befolgen. 1. Wie verwende ich das Xiaohongshu-Konto, um Benutzer zu finden? 1. Öffnen Sie die Xiaohongshu-App, klicken Sie auf die Schaltfläche „Entdecken“ in der unteren rechten Ecke und wählen Sie dann die Option „Notizen“. 2. Suchen Sie in der Notizenliste nach der Notiz, die von dem Benutzer gepostet wurde, den Sie suchen möchten. Klicken Sie hier, um die Seite mit den Notizdetails aufzurufen. 3. Klicken Sie auf der Seite mit den Notizdetails auf die Schaltfläche „Folgen“ unter dem Avatar des Benutzers, um zur persönlichen Homepage des Benutzers zu gelangen. 4. Klicken Sie in der oberen rechten Ecke der persönlichen Homepage des Benutzers auf die Schaltfläche mit den drei Punkten und wählen Sie „Persönliche Informationen“.

In Ubuntu-Systemen ist der Root-Benutzer normalerweise deaktiviert. Um den Root-Benutzer zu aktivieren, können Sie mit dem Befehl passwd ein Passwort festlegen und sich dann mit dem Befehl su- als Root anmelden. Der Root-Benutzer ist ein Benutzer mit uneingeschränkten Systemadministratorrechten. Er verfügt über Berechtigungen zum Zugriff auf und zum Ändern von Dateien, zur Benutzerverwaltung, zum Installieren und Entfernen von Software sowie zum Ändern der Systemkonfiguration. Es gibt offensichtliche Unterschiede zwischen dem Root-Benutzer und normalen Benutzern. Der Root-Benutzer verfügt über die höchste Autorität und umfassendere Kontrollrechte im System. Der Root-Benutzer kann wichtige Systembefehle ausführen und Systemdateien bearbeiten, was normale Benutzer nicht können. In dieser Anleitung werde ich den Ubuntu-Root-Benutzer untersuchen, wie man sich als Root anmeldet und wie er sich von einem normalen Benutzer unterscheidet. Beachten

So entwickeln Sie mit Laravel ein Online-Reservierungssystem für Restaurants. Mit der rasanten Entwicklung des Internets und des mobilen Internets sind Online-Reservierungen in den letzten Jahren zu einem unverzichtbaren Bestandteil des Lebens moderner Menschen geworden. Die Gastronomiebranche bildet da keine Ausnahme. Immer mehr Restaurants bieten Online-Reservierungsdienste an, um das Benutzererlebnis zu verbessern und ihren Marktanteil zu vergrößern. In diesem Artikel wird erläutert, wie Sie mit dem Laravel-Framework ein einfaches, aber voll funktionsfähiges Online-Reservierungssystem für Restaurants entwickeln, und es werden spezifische Codebeispiele bereitgestellt, um den Lesern das Lernen und Üben zu erleichtern. Umgebungseinrichtung Zuerst brauchen wir

sudo (Superuser-Ausführung) ist ein Schlüsselbefehl in Linux- und Unix-Systemen, der es normalen Benutzern ermöglicht, bestimmte Befehle mit Root-Rechten auszuführen. Die Funktion von sudo spiegelt sich hauptsächlich in den folgenden Aspekten wider: Bereitstellung von Berechtigungskontrolle: sudo erreicht eine strikte Kontrolle über Systemressourcen und sensible Vorgänge, indem es Benutzern erlaubt, vorübergehend Superuser-Berechtigungen zu erhalten. Normale Benutzer können über sudo bei Bedarf nur vorübergehende Berechtigungen erhalten und müssen sich nicht ständig als Superuser anmelden. Verbesserte Sicherheit: Durch die Verwendung von sudo können Sie die Verwendung des Root-Kontos bei Routinevorgängen vermeiden. Die Verwendung des Root-Kontos für alle Vorgänge kann zu unerwarteten Systemschäden führen, da für jeden fehlerhaften oder nachlässigen Vorgang die vollen Berechtigungen gewährt werden. Und

Dem Ubuntu-System wurden viele Benutzer hinzugefügt. Ich möchte die Benutzer löschen, die nicht mehr verwendet werden. Werfen wir einen Blick auf das ausführliche Tutorial unten. 1. Öffnen Sie die Terminal-Befehlszeile und löschen Sie den angegebenen Benutzer mit dem Befehl „sudo“ (siehe Abbildung unten). 2. Achten Sie beim Löschen darauf, dass Sie sich im Administratorverzeichnis befinden Sie verfügen nicht über diese Berechtigung, wie in der folgenden Abbildung dargestellt. 3. Wie kann nach der Ausführung des Löschbefehls beurteilt werden, ob er tatsächlich gelöscht wurde? Als nächstes verwenden wir den Befehl cat, um die passwd-Datei zu öffnen, wie in der Abbildung unten gezeigt. 4. Wir sehen, dass sich die gelöschten Benutzerinformationen nicht mehr in der passwd-Datei befinden, was beweist, dass der Benutzer gelöscht wurde, wie in der folgenden Abbildung gezeigt 5. Dann geben wir die Home-Datei ein

Analyse des Speichermechanismus für Benutzerkennwörter im Linux-System Im Linux-System ist die Speicherung des Benutzerkennworts einer der sehr wichtigen Sicherheitsmechanismen. In diesem Artikel wird der Speichermechanismus von Benutzerkennwörtern in Linux-Systemen analysiert, einschließlich der verschlüsselten Speicherung von Kennwörtern, des Kennwortüberprüfungsprozesses und der sicheren Verwaltung von Benutzerkennwörtern. Gleichzeitig wird anhand konkreter Codebeispiele der tatsächliche Ablauf der Passwortspeicherung demonstriert. 1. Verschlüsselte Speicherung von Passwörtern In Linux-Systemen werden Benutzerpasswörter nicht im Klartext im System gespeichert, sondern verschlüsselt und gespeichert. L

Wie verwende ich JavaWebsocket, um Online-Audio- und Videoanrufe zu implementieren? Im heutigen digitalen Zeitalter wird Echtzeitkommunikation immer häufiger eingesetzt. Ob Remote-Zusammenarbeit am Arbeitsplatz oder Remote-Kommunikation mit Verwandten und Freunden zu Hause, Echtzeit-Audio- und Videoanrufe sind zu einem unverzichtbaren Bestandteil der Menschen geworden. In diesem Artikel wird erläutert, wie Sie mit JavaWebsocket Online-Audio- und Videoanrufe implementieren, und es werden spezifische Codebeispiele bereitgestellt. 1. Websocket verstehenWebsocket ist eine neue Technologie in HTML5

Oracle-Datenbank ist ein häufig verwendetes relationales Datenbankverwaltungssystem, und viele Benutzer werden bei der Verwendung von Tabellenbereichen auf Probleme stoßen. In einer Oracle-Datenbank kann ein Benutzer über mehrere Tabellenbereiche verfügen, wodurch die Datenspeicherung und -organisation besser verwaltet werden kann. In diesem Artikel wird untersucht, wie ein Benutzer mehrere Tabellenbereiche in einer Oracle-Datenbank haben kann, und es werden spezifische Codebeispiele bereitgestellt. In Oracle-Datenbanken ist der Tabellenbereich eine logische Struktur, die zum Speichern von Objekten wie Tabellen, Indizes und Ansichten verwendet wird. Jede Datenbank hat mindestens einen Tablespace,
