Designed by Maunakea !
85 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 21/01/2009 (177 674 hits)
Didier Téléchargez gratuitement et légalement des logiciels Microsoft ! Si, si ;)
  • Visual Studio 2010
  • Office 2010
  • Expression Studio 3
  • SQL Server 2008
  • et d'autres...
Au fil des news  
Magazines - Le N°128 de Programmez est disponible
Magazines - Le N°127 de Programmez est disponible
Dreamweaver CS4 + Php + Mysql - Trucs et Astuces - Part 6
Pour continuer dans le même style, je vous propose une suite au précédent article. Rechercher tous ...
Adobe - Adobe Photoshop.com Mobile pour iPhone 1.1
JavaScript - Ajouter une page dans vos favorites
Dreamweaver CS4 + Php + Mysql - Trucs et Astuces - Part 5 -
Je vous propose cette fois deux astuces. Comment exporter une feuille de style avec l'aide de ...
SharePoint Personalization Site Links - Les liens personnalisés des MySite SharePoint
Nous avons vu dans les articles précédents comment agrémenter les pages de recherche afin de ...
Magazines - Le n°126 de Programmez est disponible
Outils - Traducteur en ligne automatique pour site web
Adobe - Adobe Photoshop.com Mobile pour Iphone
Magazines - Le n°125 de Programmez est disponible
Adobe - Adobe AIR 2 et Flash Player 10.1version bêta
Les conférences autour des technologies Microsoft - Liste non exhaustive des grands évènements
Nous allons essayer de regrouper un grand nombre des évènements autour des technologies Microsoft ...
Magazines - Le n°124 de Programmez est disponible
PHP - Forum PHP 2009
Composants - eFace - XAML en Java
WPF - Désactiver le bouton de réduction d'une fenêtre
Magazines - Le n°123 de Programmez est disponible
Magazines - Le n°122 de Programmez est disponible
Auditer une ferme SharePoint - Assurer le bon fonctionnement de SharePoint
Dans le cadre de la bonne gestion de son environnement SharePoint, il est utile de faire un ...
SQL Server 2008 Report Builder 2.0 - Installation et utilisation de Report Builder 2.0
Dans le cadre de la création de rapports pour SQL Server Reporting Services 2008, un outil est ...
Magazines - Le HS N° 1 de Web Design est disponible
Adobe - Adobe propose en Open Source les frameworks.....
Outils - EntityBuilder
CSharp - Sérialisation XML de vos objets
Magazines - Le n°121 de Programmez est disponible
Adobe - Adobe annonce MAX 2009 !
Outils - WhoIs
[MAJ] Dreamweaver MX + Php + MySql - Les formulaires - partie 3
Mise à jour du code, par DB 77, affichage du code erreur, dans la page erreur.php, traduction des ...
PHP - News avec photo - Système de gestion - affichage
Gestion - Administration - Affichage d'une "News", "Actualité", "Info", ... avec : - mise en forme ...
Outils - Crypt
Dreamweaver Php Mysql - Région répétée imbriquée
Je rebondis, sur un post du forum, pour vous montrer comment obtenir grâce à l'extension Simulated ...
Magazines - Le n° 120 de Programmez est disponible
Gérer les bases de contenu SharePoint - Gérer la croissance du volume des données
Dans le cadre de la gestion quotidienne de ferme SharePoint, il existe une partie qu'il faut ...
PHP - Le Coach PHP sur Visual Studio
.NET - Ecrire une application .NET utilisant MySQL
PHP - Utilisation de PHP dans le monde Microsoft
Magazines - Le n° 119 de Programmez est disponible
Adobe - Adobe annonce Photoshop Marketplace
[MAJ] Tutoriel AJAX simple - En avant vers le WEB2.0
Mis à jour le 20/04/2009
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
v3b © Didier 2003   
 

Corpo Sciences de Reims Partitions gratuites Carte, météo, annonces
 ASP-magazine Groupes Utilisateurs Microsoft DotNet Project TechNet MVP