Designed by Vince El Roubio !
71 en ligne   Boutique | Sites | Bar | Forum | PhpBB | Actu | Glossaire | Codes | Tips | Liens | Livres | Lettre  


 Recherche

 NewsLetter





   

PHPChat v1.2

Un chat en PHP





Démo - Administration - Download (v 1.2)



LES VERSIONS

version 1.2
- nom d'utilisateur
le nom de l'utilisateur connecté est géré par session. Dans la page de connexion :
<?
session_start();
session_register("log");
$log = $lelog;
?>


où $lelog est le login saisi dans le formulaire de connexion. $log est la variable de session qui sera utilisée tout au long de l'application.

- gestion de codes html et javascript saisis dans le message
Ces instructions ne seront plus supprimées du message, mais recopiées telles quelles (remplacement des caractères < et > par leurs code < et >)

- interface d'admin
un nouvelle petite page, admin.php, apparait et permet de gérer les utilisateurs connectés et les messages. Pour les utilisateurs, il s'agit seulement de les déconnecter; si la personne que l'admin déconnecte est toujours présente sur le chat, elle sera avertie par une alert javascript et sa fenêtre sera fermée, mais cette fonctionnalité est mise en place pour supprimer les éventuelles personnes qui ne sont pas déconnectées mais plus présentes sur le chat. Pour les messages, c'est la suppression de tous les posts.

version 1
C'est celle décrite ci-dessous! L'application est assez simple, et n'utilise aucune base de données; les messages sont stockés dans un fichier texte.

FICHIERS DE L'APPLICATION
L'arborescence des fichiers est la suivante :
répertoire de baserépertoire de base
   | datasrépertoire qui contient le fichier des messages, et les infos sur les connectés
      messages.txtfichier qui contient les 50 derniers messages.
   | imagesrépertoire qui contient les images utilisées pour le chat
      | smileysrépertoire qui contient les smileys
   cFin.phpfichier qui gère les déconnexions
   cMessages.phpfichier qui affiche la liste des messages
   cSaisie.phpfichier du formulaire de saisie des messages
   cSmiley.phpfichier d'affichage des smileys
   cUsers.phpfichier d'affichage de la liste des utilisateurs connectés
   cVide.phpfichier de vérification des nouveaux messages arrivants
   index.phpfichier du formulaire de connexion
   main.phpfichier qui contient les frames de l'application


remarque
   - penser à donner, sur un serveur qui tourne sous Unix, les droits d'écriture au répertoire datas.

FONCTIONNALITES DU CHAT
Les points suivants sont gérés dans cette version 1 du chat :

   - utilisateurs connectés
   - smileys
   - action telles que le /me de Irc, le /away ou le /back


FONCTIONNEMENT DU CHAT
Je ne reviendrai pas sur le formulaire de login. Voir pour cela :
le tutorial sur les formulaire
les exercices sur les mots de passe

Les points importants :

rafraichissement de la frame des messages
Dans un chat, rien n'est plus ennuyeux que de voir clignoter, toutes les 5 secondes par exemple, la liste des messages lors du rafraichissement des données. Ce rafraichissement est cependant nécessaire pour afficher les nouveaux messages.
Ici, ce rafraichissement n'intervient que si il y a des messages récents, et non pas de façon régulière.
Pour ce faire, une page se rafraichit elle même toutes les 5 secondes, mais dans une frame de taille 0 : on ne verra pas de clignottement. C'est la page cVide.php.

gestion des messages
Dans cette version, seul les 50 derniers messages sont conservés, ce qui est amplement suffisant et permet de ne pas trop ralentir le tout.
L'ajout d'un message se fait dans le fichier cSaisie.php, et la consultation est effectuée grâce à cMessages.php
L'affichage des messages est tout simple, et consiste seulement à include le fichier des messages dans la page...
La saisie est un peu plus complexe, en revanche :
    - gestion du code javascript, envoyé dans le message
      Pour des raisons de sécurité, tout ce qui se situe entre <script> et </script> est effacé. Le code html est, quant à lui, interprété.
      Voici le code de suppression du javascript :
<?
while (ereg("<script.*</script>", $message)) {
    $message = ereg_replace("(.+)<script.*</script>(.+)", "\\1 \\2", $message);
}
?>


    - gestion des smileys
      le code du smiley, envoyé dans le message, est remplacé par son image. Ce code est généré par le fichier cSmileys.php, et est en fait tout simplement une petite transformation du nom de l'image.

gestion des smileys
Afin de ne pas avoir à taper le nom et le chemin complet de son image, chaque smiley est associé à un code, qui sera saisi dans le message et retrnasformé à l'insertion dans le fichier des messages.
Cette gestion se fait en 2 étapes :
    - affichage de la liste des smileys
      cette page cSmileys.php permet de ne pas avoir à retenir le code de tous les smileys. Aisni, en choisissant parmi la liste un smiley, son code sera rapatrié dans le formulaire de saisie.
      le code d'affichage de la liste des smileys est le suivant :
<?
// parcours du répertoire qui contient les smileys, et remplissage du tableau
$lesM = dir("images/smileys/");
$i = 0;
while ($entryName = $lesM->read()) {
    if ( ($entryName!=".") && ($entryName!="..") ){
        $tabM[$i] = $entryName;
        $i++;
    
}
$lesM->close();
BubbleSort($tabM); // tri suivant le nom

$i = 0;
// boucle d'affichage des images
echo "<table width=\"100%\" align=\"center\">";
while ($i<count($tabM)) {
   echo "<tr><td width=\"100%\" align=\"center\">";
   echo "<a href=\"#\" onClick=\"javascript:chx_smiley('";
   echo substr($tabM[$i], 0, strLen($tabM[$i])-4) . "');\">";
   echo "<img src=\"images/smileys/" . $tabM[$i] ."\"></a></td></tr>";
    $i++;   
}
echo "</table>";
?>


      et la fonction qui permet de rapatrier le code du smiley en fonction de son nom :
<script language="javascript">
function chx_smiley(sNom) {
    opener.saisie_message.message.value = opener.saisie_message.message.value+" [S"+sNom+"S] ";
    opener.saisie_message.message.focus();
    window.close();
}
</script>


      Le code sera toujours entouré de [S et S], des "marqueurs", qui pemettront pas la suive de repéré le smiley dans le message.
    - transformation du code en chemin+nom de l'image à afficher
      cette opération est effectuée dans cSaisie.php, après récupération du message, et avant insertion dans le fichier.
      Script de récupération du nom de l'image en fonction de son code :
<?
while (ereg("\[S.*S\]", $message)) {
    $message = ereg_replace("(.+)\[S(.+)S\](.+)", "\\1<img src='images/smileys/\\2.gif'>\\3", $message);
}
?>



gestion des connexions/déconnexions
Afin de savoir qui est connecté au chat, il est nécessaire de stocker une information au login, puis de l'effacer lors que la fenêtre du chat se ferme.
    - connexion
      lorsque le login est saisie, et que la page de création des frames est appelée , un fichier est créé, dans le répertoire datas. Son nom est le pseudo de la personne conecté. Peu importe ce qu'il contient, l'important est son existence.
      Si, lors de la connexion, le pseudo est déjà utilisé, une erreur survient, et la personne n'entre pas sur le chat.
      Code de gestion de l'existence du pseudo :
<?
if (file_exists("datas/" . $log)) {
    die("<META HTTP-equiv='refresh' content='0;URL=index.php?interdiction=2'>");
} else {
    die("<META HTTP-equiv='refresh' content='0;URL=main.php?log=" . $log . "'>");
}
?>


      Code de création du fichier :
<?
$tmp = fopen("datas/" . $log, "w");
fputs($tmp, "sdfsdfd");
fclose($tmp);
?>


    - déconnexion
      la déconnexion est gérée lors de la fermeture de la frame principale. Une petite fenêtre s'ouvre, et le seul code consiste à supprimer le fichier correspondant au pseudo utilisé. Le fichier qui fait cette action est cFin.php.
      Code de destruction du fichier :
<?
unlink("datas/" . $log);
?>




VOIR AUSSI
formulaires
gestion ds fichiers
expressions régulières
exercices sur les mots de passe

Pour pouvoir écrire dans ce forum, identifiez-vous !

  v1.3p © ASP-PHP.net 2002  

Wargoat le 28/01/2004 (159 795 hits)
Didier Ils l’ont fait avec SQL Server. Découvrez comment !
Concours de programmation Flash !
Au fil des news  
ASP - Redimensionner Image + Picto après Upload - Galerie photos, revue de presse, ...
But : Proposer aux visiteurs de charger des images sans se soucier du "poids" de l'image, puisqu'on ...
Exporter et Importer un site SharePoint - Comment déplacer un site SharePoint
Une question est très régulièrement posée à tout responsable de ferme SharePoint : Comment ...
Bon anniversaire - Comment le souhaiter à ses membres ?
Avoir un site, c'est bien. Avoir des inscrits, c'est mieux. Souhaiter leur anniversaire, c'est ...
Audio & Vidéo - Multimédia dans ses pages web
AUDIO/VIDEO : QuickTime, MediaPlayer, RealPlayer, FlashPlayer, ... : Du multimédia dans ses pages ...
Magazines - Le Hors-Série .Net de Programmez !
PHP - Administrer en ligne - Protection des pages
Protéger ses pages pour administrer son site en ligne en (relative) sécurité (PHP).
Communautés - Concours de programmation Flash !
[MAJ] Afficher ses images à la taille voulue - Utilisation du composant IMGSIZE
Ajout de la vérification de l'existence du fichier et d'un test d'erreur de retour du composant ...
Protéger ses Images - Propriété intellectuelle - Vie privée
Je me suis penché sur la question en tant qu'artiste moi-même, et concepteur de site web pour ...
Création de miniatures - Fonction php de création
Cette fonction sert à créer des miniatures.
ASP - ADMINISTRER en ligne - Protection des pages
Protéger ses pages pour administrer son site en ligne en (relative) sécurité (ASP).
JavaScript - Numéros de ligne à gauche d'un textarea
Protection - Sécurité - Mise au point - Précautions - Solutions
Même sans être paranoïaque, on a tous entendu parler de failles de sécurité, piratage informatique, ...
AspSmartUpload - Mode d'Emploi
Le composant ASPSmartUpload (gratuit) permet de gérer les téléchargements de FICHIERS ou de ...
JavaScript - Contrôler une date saisie dans un formulaire
HTML - Ajouter un fichier multimédia dans une page web
HTML - Musique de Fond sur son site
Afficher ses images à la taille voulue - Utilisation du composant IMGSIZE
Devant la diversité des formats d'image actuels, il est parfois nécessaire de connaître les ...
CSS - Icône Personnalisée sur son site
JavaScript - Interdire Clic Droit et message d'alerte
CSS - Curseur Personnalisé sur son site
JavaScript - Fenêtre à la Dimension de l'Ecran
La gouvernance SharePoint - Partie 1 - Première partie sur la gouvernance dans Sharepoint
Un projet de mise en place de ferme SharePoint est un projet important pour toute structure ...
ASP - Redimensionner Image + Picto après Upload
ASP - Administration en ligne : Protection des Pages
PHP - Administration en ligne : Protection des Pages
PHP - Redimensionner Image + Picto après Upload
ASP - Boutons ON OFF pour tout type de musique
PHP - Boutons ON OFF pour tout type de musique
SharePoint et OpenSearch - Utiliser l'option OpenSearch avec SharePoint
Nous avons maintenant un site SharePoint fonctionnel associé à un moteur de recherche efficace. Il ...
Magazines - Le n°109 de Programmez est disponible
SharePoint et PowerShell - Utilisation de PowerShell pour un script d'admin
PowerShell est le nouveau moteur de script de Microsoft. Il permet tout comme VBScript de créer des ...
[MAJ] [PHP] - Validation de formulaire - Gestion des erreurs via style CSS
Ajout de la sécurité anti sql injection de premier niveau.
Adobe - Adobe propose 3 nouvelles versions bêta publiques
VBScript - Interroger un serveur MYSQL
Divers - Web developpement
PHP5 - Copie de fichiers distants
Les stratégies de Backup dans WSS V3 - Quelles sont les différentes solutions de BackUp
Nous avons vu au travers des précédents articles différents sujets pour Windows SharePoint Services ...
Création d'une solution de déploiement SharePoint - Créer la solution pour notre composant SharePoint
Après avoir suivi toutes les étapes pour la création de notre composant (Feature) SharePoint, il ...
Magazines - Le n°108 de Programmez est disponible
Tutorial : HTML | Scripting | ASP-PHP | ASP.net | SQL Server | XML
Sharepoint | XAML | Pocket | Dreamweaver | VML | Divers
  Scripts : Scripting | ASP-PHP | ASP.net | Divers
  Boutique | Annuaire | Bannières | Météo | Tribune | Partenariats
v3 © Didier 2003   
 

Corpo Sciences de Reims Partitions gratuites Carte, météo, annonces
 Wygwam DotNet Project Codes Sources The Inquirer FR ASP-magazine TechNet El Roubio CodePPC MVP Groupes Utilisateurs Microsoft