IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

PHP & Base de données Discussion :

online offline avec puce


Sujet :

PHP & Base de données

  1. #1
    Membre régulier
    Homme Profil pro
    Inscrit en
    Octobre 2004
    Messages
    514
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 57
    Localisation : Belgique

    Informations forums :
    Inscription : Octobre 2004
    Messages : 514
    Points : 107
    Points
    107
    Par défaut online offline avec puce
    bonjour voilà j'essaye de mettre au point un fonction online / offline pour toute la structure du quand les autres membres sont en ligne ;

    je fait cela pour le moment

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    <?PHP					
    if(isset($_SESSION['login'])){
      if(isset($_SESSION['type_site'])){
     
    $requete_nombre_connecte = $connection->prepare('SELECT COUNT(*) pseudo_site FROM online_site WHERE pseudo_site=:pseudo_site');
    if($requete_nombre_connecte->execute(array(':pseudo_site'=> $_SESSION['login']))){
      $connecte = $requete_nombre_connecte->fetchColumn();
     
        if($connecte >0){
                    $udapte_connecte = ('UPDATE online_site SET timestamp=:timestamp WHERE pseudo_site=:pseudo_site');	
                    $req_connecte = $connection->prepare($udapte_connecte);			
                    $req_connecte->execute(array(':timestamp'=> date("Y-m-j H:i:s"),':pseudo_site'=> $_SESSION['login']));	
            }else{
                    $connecte_online = array(
                            ':timestamp'=> date("Y-m-j H:i:s"),
                            ':pseudo_site'=> $_SESSION['login'],
                    ':type'=> $_SESSION['type_site']);	
     
                     $values= join(', ',array_keys($connecte_online));
                     $req=$connection->prepare( 'INSERT INTO online_site ('.str_replace(':','',$values).') VALUES('.$values.')' );
                     $req->execute($connecte_online);
           }
            }
         }
      }
    $requete = 'SELECT pseudo_site,type FROM online_site ';
    if (!empty($_POST['type'])) {
        // si on a reçu un type, on filtre dessus
        $requete = $requete.' WHERE type=:type';
        // on ajoute la valeur de type aux paramètres d'exécution de la requête
        $params['type']  = $_POST['type'];
    }
    @$connect = $connection->prepare($requete);
    @$connect->execute($params);		
    $typef = 'Femme';
    $typeh = 'Homme';	 
     echo'<FORM method="POST" action="'.$_SERVER['PHP_SELF'].'">
         <input type="image" src="imdesign/f.png" title="Femme" width="30" height="30" border="0" name="type" value="'.$typef.'" />
       <input type="image" src="imdesign/h.png" title="Homme" width="30" height="30" border="0" name="type" value="'.$typeh.'" />
         </FORM>';
    while($result = $connect->fetch()){
     $online = $result['pseudo_site'];
     $ballColor = 'verte';
      // Test du paramètre d'entrée
      if ($online == 1) {
        $ballColor = 'rouge';
      }
     
       echo'<img src="imdesign/bille_' , $ballColor , '.png" width="15" height="15"><b>'.$result['pseudo_site'].'</b>
       <a href="http://'.$_SERVER['HTTP_HOST'].dirname($_SERVER['PHP_SELF']).'/envoyez_message.php?destin='.$result['pseudo_site'].'"><img src="imdesign/envois.png" width="20" height="15" /></a></br>';
     
    $connection->exec('DELETE FROM online_site WHERE timestamp< DATE_SUB(NOW(), INTERVAL 2 MINUTE)');
        }
     
    ?>

  2. #2
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Points : 44 155
    Points
    44 155
    Par défaut
    As-tu une question ? une difficulté ? un dysfonctionnement ?
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  3. #3
    Membre régulier
    Homme Profil pro
    Inscrit en
    Octobre 2004
    Messages
    514
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 57
    Localisation : Belgique

    Informations forums :
    Inscription : Octobre 2004
    Messages : 514
    Points : 107
    Points
    107
    Par défaut
    Bonjour sabotage
    j'essaye de mettre au point une fonction online offline pour tout le site.
    je teste cela juste voir si me structure est bonne et si je suis dans la bonne direction.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    <?PHP
    $online_sortie  = $connection->prepare('SELECT * FROM online_site'); 
    $online_sortie->execute(array());
    while($data_online = $online_sortie->fetch(PDO::FETCH_OBJ)){
     
    if(!empty($data_online->pseudo_site)){
    setcookie('pseudo', ''.$data_online->pseudo_site.'', time() + 60*60*2, null, null, false, true); // On écrit un cookie
    }else{
    	setcookie('pseudo');
    }
     
     $online_user =($_COOKIE["pseudo"] == $_SESSION['login']); 
     
    }
     function online_user($online_user){
        // Test du paramètre d'entrée
        if ($online_user == 1){
    	  echo'<img src="imdesign/bille_verte.png" width="15" height="15">';
        }
    	echo'<img src="imdesign/bille_rouge.png" width="15" height="15">';
      }
     
    ?>
    Notice: Undefined index: pseudo in C:\Program Files\EasyPHP-5.3.8.1\www\source\fonction_online.php on line 12

    j'ai bien la puce mais plus le pseudo

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    profil_membre.php.php?nom='.$pseudo.'"style="color:#0000FF;">'.online_user($pseudo).'</a>';

Discussions similaires

  1. online user avec puce.
    Par speedylol dans le forum jQuery
    Réponses: 1
    Dernier message: 13/01/2017, 14h21
  2. [MySQL] Fonction online/offline
    Par toulousain3117 dans le forum PHP & Base de données
    Réponses: 8
    Dernier message: 24/02/2007, 08h37
  3. probleme avec puces crées en javascript
    Par GTJuanpablo dans le forum Général JavaScript
    Réponses: 12
    Dernier message: 13/02/2006, 14h56
  4. li en ligne avec puce
    Par malbaladejo dans le forum Balisage (X)HTML et validation W3C
    Réponses: 8
    Dernier message: 04/11/2005, 13h39
  5. [SYBASE]robleme de database offline avec sybase
    Par arioule dans le forum Sybase
    Réponses: 3
    Dernier message: 25/02/2005, 15h40

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo