Navigazione

    Privacy - Termini e condizioni
    © 2020 Search On Media Group S.r.l.
    • Registrati
    • Accedi
    • CATEGORIES
    • Discussioni
    • Non letti
    • Recenti
    • Hashtags
    • Popolare
    • Utenti
    • Stream
    • Interest
    • Categories
    1. Home
    2. Categorie
    3. Coding e Sistemistica
    4. Coding
    5. Problema sessioni utenti
    Questa discussione è stata cancellata. Solo gli utenti con diritti di gestione possono vederla.
    • S
      sups User Attivo • ultima modifica di

      Il logout non è obbligatorio terminare la sessione, puoi anche implementare una variabile di sessione che indica la presenza sul sito web dell'utente.
      Il compito della pagina richiamata da "onunload" è quello di azzerare questa variabile.

      0 Miglior Risposta Ringrazia Cita Rispondi

        1 Risposta Ultima Risposta
      • R
        ryu66 User • ultima modifica di

        e come si fa a settare questa variabile chiudendo solamente il browser???

        0 Miglior Risposta Ringrazia Cita Rispondi

          1 Risposta Ultima Risposta
        • D
          digital.daigor User Attivo • ultima modifica di

          il sistema è più o meno questo:

          una pagina che fai girare ogni TOT, che modifica gli user collegati, aggiornando il timestamp nel DB, e cancella quelli fuori dal timeout.

          esempio:

          [PHP]
          $timeout = time()-60;//Timeout di 1 minuto

          $query = "UPDATE utenti_collegati SET timeout='".time()."' WHERE id=1";
          mysql_query($query);

          $query = "DELETE FROM utenti_collegati WHERE timeout < '".$timeout."''";
          mysql_query($query);

          $query = "SELECT * FROM utenti_collegati";
          $rsq = mysql_query($query);
          while($rwq = mysql_fetch_assoc($rsq))
          {
          echo $rwq['user];
          }

          [/PHP]

          l'ho fatta al volo, ma più o meno è così!

          fammi sapere!

          0 Miglior Risposta Ringrazia Cita Rispondi

            1 Risposta Ultima Risposta
          • R
            ryu66 User • ultima modifica di

            si ma in questo modo non mi cancellerebbe anche quegli che hanno la pagina aperta per più di un minuto senza aggiornare???

            0 Miglior Risposta Ringrazia Cita Rispondi

              1 Risposta Ultima Risposta
            • D
              digital.daigor User Attivo • ultima modifica di

              se fai un ajax o un iframe, fai aggiornare ogni TOT secondi!

              con ajax, magari usando jquery, ti viene molto facile, e fai una chiamata al DB ogni utente, il ke, con molti utenti contemporaneamente, può essere una rottura, ma se il timeout va ogni 5 minuti....i danni collaterali diminuiscono!

              0 Miglior Risposta Ringrazia Cita Rispondi

                1 Risposta Ultima Risposta
              • R
                ryu66 User • ultima modifica di

                ho un pò modificato il tuo codice

                [PHP]
                $timeout = time() -60; //Timeout di 1 minuto

                $query_timeout = "UPDATE sessioni SET timeout='".time()."' WHERE id='".$_COOKIE["sessioni"]."'";
                $result_timeout = mysql_query($query_timeout) OR DIE (mysql_error());

                $query_timeout_set = "UPDATE sessioni SET online='0' WHERE timeout < '".$timeout."''";
                $result_timeout_set = mysql_query($query_timeout_set) OR DIE (mysql_error());
                [/PHP]

                non so il perchè quando lo carico mi da questo errore:

                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 ''1212142592''' at line 1

                0 Miglior Risposta Ringrazia Cita Rispondi

                  1 Risposta Ultima Risposta
                • D
                  digital.daigor User Attivo • ultima modifica di

                  < '".$timeout."''"

                  doppia chiusura apice....sorry!

                  0 Miglior Risposta Ringrazia Cita Rispondi

                    1 Risposta Ultima Risposta
                  • R
                    ryu66 User • ultima modifica di

                    ora va , però c'è un'altro problema appena mi connetto mi setta direttamente online = '0' senza aspettare 1 minuto

                    0 Miglior Risposta Ringrazia Cita Rispondi

                      1 Risposta Ultima Risposta
                    • D
                      digital.daigor User Attivo • ultima modifica di

                      in che senso?

                      ti connetti, hai il cookie attivo e ti setta sempre a 0???

                      0 Miglior Risposta Ringrazia Cita Rispondi

                        1 Risposta Ultima Risposta
                      • R
                        ryu66 User • ultima modifica di

                        si , setta il timeout anche

                        0 Miglior Risposta Ringrazia Cita Rispondi

                          1 Risposta Ultima Risposta
                        • D
                          digital.daigor User Attivo • ultima modifica di

                          time() +60

                          prova così!

                          0 Miglior Risposta Ringrazia Cita Rispondi

                            1 Risposta Ultima Risposta
                          • R
                            ryu66 User • ultima modifica di

                            uguale

                            0 Miglior Risposta Ringrazia Cita Rispondi

                              1 Risposta Ultima Risposta
                            • D
                              digital.daigor User Attivo • ultima modifica di

                              mi raccomando......il timeout, dovrebbe essere il doppio del tempo di chiamata della pagina con ajax o iframe....

                              es:

                              ajax: timeout 1 minuto
                              php: timeou 2 min

                              0 Miglior Risposta Ringrazia Cita Rispondi

                                1 Risposta Ultima Risposta
                              • R
                                ryu66 User • ultima modifica di

                                ho provato qualsiasi variazione di tempo, appena mi connetto mi da direttamente il set a 0

                                0 Miglior Risposta Ringrazia Cita Rispondi

                                  1 Risposta Ultima Risposta
                                • D
                                  digital.daigor User Attivo • ultima modifica di

                                  fai l'echo di tutte le query, e postale

                                  0 Miglior Risposta Ringrazia Cita Rispondi

                                    1 Risposta Ultima Risposta
                                  • R
                                    ryu66 User • ultima modifica di

                                    1
                                    [PHP] UPDATE sessioni SET timeout= '1212147255' WHERE id='14'[/PHP]

                                    2

                                    [PHP] UPDATE sessioni SET online= '0' WHERE timeout < '1212147043'[/PHP]

                                    0 Miglior Risposta Ringrazia Cita Rispondi

                                      1 Risposta Ultima Risposta
                                    • D
                                      digital.daigor User Attivo • ultima modifica di

                                      caspita......non avevo calcolato la variabile online.....

                                      nella query prima, setta anche quella!!!

                                      UPDATE sessioni SET timeout= '1212147255', online = '1' WHERE id='14'

                                      0 Miglior Risposta Ringrazia Cita Rispondi

                                        1 Risposta Ultima Risposta
                                      • R
                                        ryu66 User • ultima modifica di

                                        no non centra quella perchè già sopra in unaltro script me la setta a ogni riaggiornamento

                                        0 Miglior Risposta Ringrazia Cita Rispondi

                                          1 Risposta Ultima Risposta
                                        • D
                                          digital.daigor User Attivo • ultima modifica di

                                          le query fanno il loro dovere, fagli fare delle select e fagli restituire il risultato prima durante e dopo

                                          0 Miglior Risposta Ringrazia Cita Rispondi

                                            1 Risposta Ultima Risposta
                                          Caricamento altri post
                                          Rispondi
                                          • Topic risposta
                                          Effettua l'accesso per rispondere
                                          • Da Vecchi a Nuovi
                                          • Da Nuovi a Vecchi
                                          • Più Voti