[PHP] Limitare login ad un solo utente per volta

PietroDeRosa

Nuovo Utente
19 Mar 2018
20
0
1
31
Buongiorno a tutti,

ho due quesiti da porre, ma problemi diversi quindi aprirò due topic per non creare confusione.

Il primo cioè il seguente riguarda la necessità di dover gestire un login dove devo consentire l'accesso ad un solo utente per volta, nel senso che ho 3 user nel mio db e vorrei che per ognuno dei 3 user fosse consentita una sola e singola connessione.

Attualmente la mia pagina di login è questa

PHP:
<?php
@session_start();
$host = 'xxx';
$user = 'xxx';
$password = 'xxx';
$database = 'xxx';
$port = 3306;
$db = new mysqli($host, $user, $password, $database);
// Check connection
if ($db->connect_error) {
    die("Connection failed: " . $db->connect_error);
}
$known_user = 'PIPPO';
$known_pwd = 'PLUTO';
$utente = filter_input(INPUT_POST, 'user');
$paswrd = filter_input(INPUT_POST, 'pass');
$sql = "SELECT * FROM MOBILE WHERE UTENTE = '".$utente."' AND PASWRD = '".$paswrd."'";
$result = $db->query($sql);

if ($result->num_rows > 0) {
    $data = $result->fetch_assoc();
    $_SESSION['db_params'] = array(
        'user' => $data['UTENTE'],
        'host' => $data['IP'],
        'db_user' => $data['UTE'],
        'db_pwd' => $data['PWD'],
        'db_name' => $data['DB'],
    );
}
header('Location: index.php');
$db->close();
 

otto9due

Utente Attivo
22 Feb 2014
529
21
28
In questo caso creerei una tabella nel database es: "login" dove inserirei un solo campo con valore uno o zero. Nel caso di login effettuato il valore si sposta a uno in caso di Logout il valore si sposa a zero. In questo modo se si tenta una login puoi sapere che valore ha il campo login e quindi capire se qualcuno è loggato. Il problema a questo punto potresti averlo se qualcuno dimentica di sloggarsi..


Saluti G.G.
 

PietroDeRosa

Nuovo Utente
19 Mar 2018
20
0
1
31
In questo caso creerei una tabella nel database es: "login" dove inserirei un solo campo con valore uno o zero. Nel caso di login effettuato il valore si sposta a uno in caso di Logout il valore si sposa a zero. In questo modo se si tenta una login puoi sapere che valore ha il campo login e quindi capire se qualcuno è loggato. Il problema a questo punto potresti averlo se qualcuno dimentica di sloggarsi..


Saluti G.G.
Potrei però creare una disconnessione automatica dopo 30 minuti di inattività....

Il problema è un altro, non so fare né la prima (che mi hai consigliato) né la seconda :(
Qualche link di suggerimento? Un esempio pratico?
 

macus_adi

Utente Attivo
5 Dic 2017
1.333
91
48
IT/SW
Il problema a questo punto potresti averlo se qualcuno dimentica di sloggarsi
Potresti usare gli eventi di mysql, e nella tabellina che ti ha consigliato @otto9due aggiungerei il timestamp di quando l'utente si è loggato, successivamente crei l'evento e setti in automatico lo stato da 1 a 0 quando sono trascorsi x secondi!
 

otto9due

Utente Attivo
22 Feb 2014
529
21
28
Questa cosa degli eventi è la prima volta che la sento e sono molto incuriosito.. come funziona?? Ho letto che addirittura si puó impostare uno schedule o eliminarlo e modificarlo, una sorta fi cron job? Ancora non ho ben capito..


Saluti G.G.
 

PietroDeRosa

Nuovo Utente
19 Mar 2018
20
0
1
31
in realtà non essendo molto pratico a riguardo se foste così gentili da mostrarmi qualche esempio di codice, in modo da poter prendere spunto, ve ne sarei grato :)
 

macus_adi

Utente Attivo
5 Dic 2017
1.333
91
48
IT/SW
Si certo, metti in "ascolto" mysql per schedulare degli eventi, eseguire funzioni etc....

Esempio su quanto richiesto:
Tabella login
Codice:
--
-- Create table "login_"
--
CREATE TABLE login_ (
  id int(11) NOT NULL AUTO_INCREMENT,
  user_id int(11) DEFAULT NULL COMMENT 'id utente',
  f_login bigint(20) DEFAULT NULL COMMENT 'Primo login',
  last_login bigint(20) DEFAULT NULL COMMENT 'Ultimo login effettuato',
  max_time int(11) DEFAULT 1800 COMMENT 'In secondi, quindi sono 30 minuti',
  status_ tinyint(1) DEFAULT 0,
  PRIMARY KEY (id)
)
ENGINE = INNODB
AUTO_INCREMENT = 2
CHARACTER SET utf8
COLLATE utf8_general_ci
ROW_FORMAT = DYNAMIC;
Evento disabilita utente:
Codice:
-- Create event "disabilita_sessione"
--
CREATE
    DEFINER = '_r!***'@'localhost'
EVENT disabilita_sessione
    ON SCHEDULE EVERY '15' MINUTE
    STARTS CURRENT_TIMESTAMP
    DO
BEGIN

 UPDATE login_
SET status_ = 0
WHERE max_time + last_login < UNIX_TIMESTAMP(NOW())

END
 

PietroDeRosa

Nuovo Utente
19 Mar 2018
20
0
1
31
Mi da errore quando provo a creare l'evento

Codice:
-- Create event "disabilita_sessione"
--
CREATE
    DEFINER = '_r!***'@'localhost'
EVENT disabilita_sessione
    ON SCHEDULE EVERY '15' MINUTE
    STARTS CURRENT_TIMESTAMP
    DO
BEGIN

 UPDATE login_
SET status_ = 0
WHERE max_time + last_login < UNIX_TIMESTAMP(NOW())

END
[/QUOTE]

/* Errore SQL (1064): You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'END' at line 14 */

se tolgo l' END

/* Errore SQL (1064): You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '' at line 13 */
 

PietroDeRosa

Nuovo Utente
19 Mar 2018
20
0
1
31
L'errore non me lo da su user (che in quel caso sarebbe dovuto essere The user specified as a definer ('_r!***'@'localhost') does not exist), ma sull' END finale.

Ho sostituito gli asterischi con l'utente db ma continua a darmi lo stesso errore
 

PietroDeRosa

Nuovo Utente
19 Mar 2018
20
0
1
31
Penso sia questo il modo corretto

Codice:
CREATE
    DEFINER = `mobileuser`@`%` 
EVENT disabilita_sessione
    ON SCHEDULE EVERY '15' MINUTE
    STARTS CURRENT_TIMESTAMP
    DO
 UPDATE login_
SET status_ = 0
WHERE max_time + last_login < UNIX_TIMESTAMP(NOW());
 

macus_adi

Utente Attivo
5 Dic 2017
1.333
91
48
IT/SW
Codice:
SET NAMES 'utf8';
--
-- Set default database
--
USE test;
DELIMITER $$
--
-- Create event "disabilita_sessione"
--
CREATE 
    DEFINER = '!_****-#!'@'localhost'
EVENT disabilita_sessione
    ON SCHEDULE EVERY '15' MINUTE
    STARTS CURRENT_TIMESTAMP
    DO 
BEGIN
 UPDATE login_
SET status_ = 0
WHERE max_time + last_login < UNIX_TIMESTAMP(NOW())
END
$$
ALTER EVENT disabilita_sessione
    ENABLE
$$
DELIMITER ;
Così!
 
Discussioni simili
Autore Titolo Forum Risposte Data
A Limitare accesso ad alcune pagine web PHP PHP 2
A [PHP] limitare counter paginazione PHP 7
M Visulizzare immagine con php PHP 8
G [PHP] Creare script di prenotazione con controllo disponibilità. PHP 7
G leggere file txt e stampare con php il contenuto a video PHP 7
F Ricreare struttura php+mysql su Xampp Apache 0
Z PHP.INI - STMP per invio email con PHP Server Dedicati e VPS 0
M Array associativi php su 2 campi mysql PHP 10
G Invio form con PHP PHP 3
T fatture con voci fattura in php PHP 0
T ALTRO PROBLEMA CON ARRAY PHP PHP 1
M Collegamento tra form html e script php PHP 4
M Problemi con la stampa dei valori in php PHP 1
W [Cerco collaborazioni] Sviluppatore Web (PHP) Offerte e Richieste di Lavoro e/o Collaborazione 1
D passare valori da database sql a php PHP 1
L Ricezione dei dati su file php da modulo html PHP 6
E Inviare variabile a PHP da ciclo in JS Javascript 0
A form PHP prenotazione tramite query PHP 2
A Form php prenotazione di un azienda sanitaria locale presso studio medico PHP 1
F menù select dinamico da db in php PHP 3
L Problemi form Pagina php HTML e CSS 3
L php mysql non salva solo id PHP 21
L php mysql cerca e visualizza pagina PHP 0
F Il codice php è giusto? PHP 2
R Aggiornare record mysql con Ajax, jQuery e php Ajax 2
A invio massivo dati a file php Javascript 4
Z MySql injection PHP PHP 1
V PHP form intersecate PHP 0
I [Offro][Retribuito] Programmatore Php Offerte e Richieste di Lavoro e/o Collaborazione 0
P Funzione jQuery Ajax invio file a php jQuery 1
C Dopo chiusura del tag php la stringa html va a capo PHP 1
E Transaction php PHP 11
B ciclare file xml con PHP PHP 1
L Estrazione dati php Database 6
A Aiuto per pagina php PHP 0
E Php select option e ajax PHP 23
I Aiuto php Dependent Lookup PHP 0
T arretramento versione PHP... PHP 3
D problema php mysql PHP 1
D problema php mysql PHP 1
E Barra di avanzamento codice PHP PHP 4
G creazione menu a tendina e invio a pagina php PHP 1
A inserire variabile php colore in div html PHP 2
Z Video protetto con PHP PHP 0
Z Problema di sincronizzazione PAYPAL con PHP PHP 1
I Eecuzione di javascript in ciclo foreach php. PHP 7
S Libreria PHP per creare file dwg o dxf PHP 0
A [cerco - retribuito] Sviluppatore Php freelance per progetti vari Offerte e Richieste di Lavoro e/o Collaborazione 2
L Google chart php mysql PHP 2
R Download file multipli da directory php PHP 0

Discussioni simili