Précédent   Forum des professionnels en informatique > PHP > Langage > Contribuez
Contribuez Proposez vos articles, cours, tutoriels, FAQ, sources, etc. pour PHP
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
Vieux 27/08/2003, 14h51   #1
Responsable Livres & PHP
 
Avatar de RideKick
 
Date d'inscription: septembre 2006
Localisation: 01
Messages: 6 016
Par défaut Vos meilleurs Codes Source

Bonjour à tous.

Merci de poster ci-après ce que vous souhaitez mettre à la disposition de tous (votre code, ou celui d'autres sur ce forum). Ce code sera entièrement libre et gratuit.

Ce fil est un espace de stockage temporaire de vos codes avant intégration dans la page Code sources.

Précisez à chaque fois :
- Titre
- Auteur
- Champ d'application

Merci de nous aider dans ce sens et ainsi de permettre d'aider encore plus de monde.

L'équipe PHP.

Dernière modification par Yogui ; 17/10/2006 à 17h15.
RideKick est déconnecté   Envoyer un message privé Réponse avec citation
Vieux 15/09/2004, 20h13   #2
Membre émérite
 
Avatar de torvalds17
 
Date d'inscription: mars 2004
Localisation: 75013
Âge: 25
Messages: 825
Par défaut

Transformation d'un nombre de chiffres (entier) en lettres (en français, limité à 999,999,999,999)

ça marche en regroupant les chiffres par series de 3 :

Code :
<?php
 
function convertitNombreEnLettres($nombreAConvertir)
{
    $tablePuissancesDeDix = array("", "mille", "millions", "milliards");// ce qu'on affichera apres chaque serie de trois
    $tableConversionEtapeDeux = array("", "dix", "vingt", "trente", "quarante", "cinquante", "soixante", "soixante", "quatre-vingt", "quatre-vingt");// equivalent du second chiffre de la serie de 3 (la dizaine)
    $tableConversionEtapeUnOuTrois = array("", "un", "deux", "trois", "quatre", "cinq", "six", "sept", "huit", "neuf");// equivalent du premier et du troisieme chiffre de la serie de 3
    $tableConversionDeLaDizaineQuiFaitChier = array("", "onze", "douze", "treize", "quatorze", "quinze", "seize");
    $nombreAConvertir = number_format($nombreAConvertir);// on formate le nombre "a l'anglaise" avec des virgules entre les milliers
    $tableauTemporaire = explode(',', $nombreAConvertir);// on passe les milliers dans un tableau
    for($i=0; $i<count($tableauTemporaire); $i++)// on parcourt le tableau, par milliers donc
    {
        for($j=0; $j<strlen($tableauTemporaire[$i]); $j++)// on parcourt les 3 caracteres (ou moins) du millier en cours
        {
            switch($j)
            {
                case strlen($tableauTemporaire[$i])-3://si on est dans les centaines
                    if(substr($tableauTemporaire[$i], $j, 1) > 0)
                    {
                        if(substr($tableauTemporaire[$i], $j, 1) > 1)
                            echo $tableConversionEtapeUnOuTrois[substr($tableauTemporaire[$i], $j, 1)];
                        echo " cents ";
                    }
                    break;
                case strlen($tableauTemporaire[$i])-2:// si on est dans les dizaines
                    if(substr($tableauTemporaire[$i], $j, 1) > 1)
                        echo $tableConversionEtapeDeux[substr($tableauTemporaire[$i], $j, 1)];
                    if(substr($tableauTemporaire[$i], $j, 1) == 1 || substr($tableauTemporaire[$i], $j, 1) == 7 || substr($tableauTemporaire[$i], $j, 1) == 9)
                        if(substr($tableauTemporaire[$i], $j+1, 1) > 6)
                            echo "-dix";
                    break;
                case strlen($tableauTemporaire[$i])-1:// si on est dans les unites
                    if(substr($tableauTemporaire[$i], $j, 1) == 1)
                        echo " et ";
                    if(substr($tableauTemporaire[$i], $j-1, 1) == 1 ||substr($tableauTemporaire[$i], $j-1, 1) == 7 || substr($tableauTemporaire[$i], $j-1, 1) == 9)
                        if(substr($tableauTemporaire[$i], $j, 1) < 7)
                            echo "-".$tableConversionDeLaDizaineQuiFaitChier[substr($tableauTemporaire[$i], $j, 1)];
                        else
                            echo "-".$tableConversionEtapeUnOuTrois[substr($tableauTemporaire[$i], $j, 1)];
                    else
                        echo "-".$tableConversionEtapeUnOuTrois[substr($tableauTemporaire[$i], $j, 1)];
                    break;
            }
        }
        echo " ".$tablePuissancesDeDix[count($tableauTemporaire)-$i-1]." ";// à quelle multiple de 10^3 on est ?
    }
}
 
convertitNombreEnLettres(124036977);
?>
ce n'est peut etre pas optimal, alors si vous avez des suggestions ou si vous trouvez des bugs, je suis ouvert ;-)

[edit]et si certaines parties non commentées vous echappent, vous pouvez me contacter ;-)[/edit]
__________________
référence PHP, référence JavaScript,
mettez-les dans vos marque-pages et lisez-les avant de poster ici ;-)

Dernière modification par Kerod ; 10/10/2006 à 01h04. Motif: Ajouté Pages Sources
torvalds17 est déconnecté   Envoyer un message privé Réponse avec citation
Vieux 14/10/2004, 20h37   #3
Membre émérite
 
Avatar de torvalds17
 
Date d'inscription: mars 2004
Localisation: 75013
Âge: 25
Messages: 825
Par défaut

Sauvegarder la structure et les données d'une base MySQL
Code :
function dumpMySQL($serveur, $login, $password, $base, $mode)
{
    $connexion = mysql_connect($serveur, $login, $password);
    mysql_select_db($base, $connexion);
    
    $entete = "-- ----------------------\n";
    $entete .= "-- dump de la base ".$base." au ".date("d-M-Y")."\n";
    $entete .= "-- ----------------------\n\n\n";
    $creations = "";
    $insertions = "\n\n";
    
    $listeTables = mysql_query("show tables", $connexion);
    while($table = mysql_fetch_array($listeTables))
    {
        // si l'utilisateur a demandé la structure ou la totale
        if($mode == 1 || $mode == 3)
        {
            $creations .= "-- -----------------------------\n";
            $creations .= "-- creation de la table ".$table[0]."\n";
            $creations .= "-- -----------------------------\n";
            $listeCreationsTables = mysql_query("show create table ".$table[0], $connexion);
            while($creationTable = mysql_fetch_array($listeCreationsTables))
            {
              $creations .= $creationTable[1].";\n\n";
            }
        }
        // si l'utilisateur a demandé les données ou la totale
        if($mode > 1)
        {
            $donnees = mysql_query("SELECT * FROM ".$table[0]);
            $insertions .= "-- -----------------------------\n";
            $insertions .= "-- insertions dans la table ".$table[0]."\n";
            $insertions .= "-- -----------------------------\n";
            while($nuplet = mysql_fetch_array($donnees))
            {
                $insertions .= "INSERT INTO ".$table[0]." VALUES(";
                for($i=0; $i < mysql_num_fields($donnees); $i++)
                {
                  if($i != 0)
                     $insertions .=  ", ";
                  if(mysql_field_type($donnees, $i) == "string" || mysql_field_type($donnees, $i) == "blob")
                     $insertions .=  "'";
                  $insertions .= addslashes($nuplet[$i]);
                  if(mysql_field_type($donnees, $i) == "string" || mysql_field_type($donnees, $i) == "blob")
                    $insertions .=  "'";
                }
                $insertions .=  ");\n";
            }
            $insertions .= "\n";
        }
    }
 
    mysql_close($connexion);
 
    $fichierDump = fopen("dump.sql", "wb");
    fwrite($fichierDump, $entete);
    fwrite($fichierDump, $creations);
    fwrite($fichierDump, $insertions);
    fclose($fichierDump);
    echo "Sauvegarde réalisée avec succès !!";
}
à appeler sous la forme :
Code :
dumpMySQL("127.0.0.1", "root", "", "ma_base", 3);
comme toujours, si vous rencontrez un bug, ou si vous voyez des possibilités d'ameliorations. pour vos propositions ;-)

[edit]je viens de la mettre sous forme de fonction, ce qui est plus propre, et qu'on peut appeler avec des parametres... ;-)[/edit]
__________________
référence PHP, référence JavaScript,
mettez-les dans vos marque-pages et lisez-les avant de poster ici ;-)

Dernière modification par Kerod ; 15/09/2006 à 00h12. Motif: Ajouté page Sources
torvalds17 est déconnecté   Envoyer un message privé Réponse avec citation
Vieux 07/03/2005, 01h48   #4
Rédacteur
 
Avatar de genova
 
Date d'inscription: septembre 2004
Messages: 482
Envoyer un message via MSN à genova
Par défaut

Etant donné que je me lance dans un projet assez gros ou je devrais connaitre en permanance le temps d'éxécution de mes scripts à la demande, je me suis dit que faire une classe de benchmark serait utile (et tant qu'à faire autant la partager). Cette classe toute con permet de faire des benchmark (de voir le temps d'éxécution de son script à différent endroits clefs) très facilement tout en ayant deux trois statistiques (pourcentage d'éxécution du script notament) dans un joli tableau, l'utilisation :
Code :
<?php
 
// On inclu la classe
include('class_benchmark.php');
 
// On intialise le benchmark
$bench = new bench();
 
sleep(2);
 
// On pose un marqueur, l'argument est le nom du marqueur
$bench->set_mark(1);
 
sleep(3);
 
// Fin du benchmark
$bench->finish();
 
?>
Et voici la classe :
Code :
<?php
class bench
{
	// Contient les différents temps pour les étapes
	var $data = array();
 
	// Temps final
	var $end = 0;
 
	// Temps de départ
	var $start = 0;
 
	/*
	** Constructeur de la classe bench.
	** Initialise le temps de départ.
	*/
	function bench()
	{
		$this->start = $this->get_time();
	}
 
	/*
	** Créé un marqueur qui retient le temps écoulé.
	** -----
	** $name :: Nom du marqueur.
	*/
	function set_mark($name)
	{
		$this->data[] = array('name' => $name, 'time' => $this->get_time());
	}
 
	/*
	** Sauvegarde le temps final et affiche tous les temps des marqueurs,
	** avec un certain nombre de statistique.
	*/
	function finish()
	{
		$this->end = $this->get_time();
		$total = $this->end - $this->start;
 
		echo '
			<table width="800" align="center" style="border: solid 1px #000000;">
				<tr>
					<td style="background-color: #cccccc; font-weight: bold; text-align: center;" colspan="4">Benchmark</td>
				</tr>
				<tr>
					<td style="background-color: #dddddd; width: 400px; text-align: center;" colspan="2">Temps d\'éxécution total :</td>
					<td style="background-color: #eeeeee; text-align: center;" colspan="2">' . ($total) . '</td>
				</tr>
				<tr>
					<td style="background-color: #cccccc; font-weight: bold; text-align: center;" colspan="4">Marqueurs</td>
				</tr>
				<tr>
					<td style="background-color: #dddddd; width: 200px; text-align: center; font-weight: bold;">Nom du marqueur</td>
					<td style="background-color: #eeeeee; width: 200px; text-align: center; font-weight: bold;">Temps du marqueur</td>
					<td style="background-color: #eeeeee; width: 200px; text-align: center; font-weight: bold;">Temps passé</td>
					<td style="background-color: #dddddd; width: 200px; text-align: center; font-weight: bold;">Pourcentage d\'éxécution</td>
				</tr>
				<tr>
					<td style="background-color: #dddddd; width: 200px; text-align: center;">Temps de départ :</td>
					<td style="background-color: #eeeeee; width: 200px; text-align: center;">' . ($this->start) . '</td>
					<td style="background-color: #eeeeee; width: 200px; text-align: center;">' . (0) . '</td>
					<td style="background-color: #dddddd; width: 200px; text-align: center;">0%</td>
				</tr>
		';
		foreach ($this->data AS $v)
		{
			$time_added = $v['time'] - $this->start;
			$percent = ($time_added / $total) * 100;
			echo '
				<tr>
					<td style="background-color: #dddddd; width: 200px; text-align: center;">Marqueur ' . $v['name'] . ' :</td>
					<td style="background-color: #eeeeee; width: 200px; text-align: center;">' . ($v['time']) . '</td>
					<td style="background-color: #eeeeee; width: 200px; text-align: center;">' . ($time_added) . '</td>
					<td style="background-color: #dddddd; width: 200px; text-align: center;">' . round($percent) . '%</td>
				</tr>
			';
			$before = $v['time'];
		}
		echo '
				<tr>
					<td style="background-color: #dddddd; width: 200px; text-align: center;">Temps d\'arrivé :</td>
					<td style="background-color: #eeeeee; width: 200px; text-align: center;">' . ($this->end) . '</td>
					<td style="background-color: #eeeeee; width: 200px; text-align: center;">' . ($total) . '</td>
					<td style="background-color: #dddddd; width: 200px; text-align: center;">100%</td>
				</tr>
			</table>
		';
	}
 
	/*
	** Renvoie un temps pour le benchmark.
	*/
	function get_time()
	{
		$ary = explode(' ', microtime());
		return ($ary[0] + $ary[1]);
	}
}
?>
__________________
Testez le forum Fire Soft Board, un forum libre, gratuit et français.

Système de template de phpBB - Lisez la FAQ PHP avant toute question si vous débuttez en PHP.
genova est déconnecté   Envoyer un message privé Réponse avec citation
Vieux 09/04/2005, 11h30   #5
Membre à l'essai
 
Date d'inscription: août 2004
Messages: 40
Envoyer un message via MSN à Antickriszt
Par défaut

bonjour à tous... voilà un petit script qui permet de générer des galeries d'images...
la page index.php doit être uploadée au même niveau qu'un répertoire de dossiers contenant soit des sous dossiers soit des galeries...
le script s'occupe de générer les pages pour la navigation dans les sous dossiers, un moteur de recherche (ultra simple) pour rechercher des galeries , ainsi que les vignettes d'apercu des images dans les galeries...

un petit exemple d'utilisation de mon script

télécharger l'archive

et pour toute question, antickriszt@hotmail.com
(pas eu le temps de faire un readme complet, désolé....)

Dernière modification par Kerod ; 15/09/2006 à 00h12. Motif: Ajouté page Sources
Antickriszt est déconnecté   Envoyer un message privé Réponse avec citation
Vieux 21/05/2005, 04h19   #6
Membre à l'essai
 
Date d'inscription: juin 2004
Messages: 43
Par défaut

Script permettant à des personnes qui ont une adresse IP dynamique (non Fixe quoi )et d'un hébergeur PHP d'avoir une redirection automatique sur leur machine ou d'un affichage "SERVEUR INDISPONIBLE" si le serveur web est coupé.
Je l'utilise pour avoir une redirection de mon site sur Free vers mon PC

1/ Le fichier ip.php sur le serveur de Free
Code :
 
<?
header("Expires: Mon, 26 Jul 1997 05:00:00 GMT");
header("Last-Modified: " . gmdate("D, d M Y H:i:s") . " GMT"); 
header("Cache-Control: no-store, no-cache, must-revalidate");
header("Cache-Control: post-check=0, pre-check=0", false);
header("Pragma: no-cache");
echo $_SERVER['REMOTE_ADDR'];
?>
 
2/Une page hs.php qui affiche un message "serveur indisponible"

3/Un script lancé en local par la commande
Citation:
php -f redirection_free.php
il faut pour cela que votre PHP soit configuré pour fonctionner en mode CGI (je crois ça se dit comme cela, je suis pas sûr car je débute sur PHP et tout ce qui concerne le développement sur le web alors sorry si je raconte des anneries)

4/le script redirection_free.php
Code :
 
<?php
$old_adresse    = "";
$adrese_ip        = "";
 
//-o0o- Boucle infinie                                                -o0o-
//-o0o---------------------------------------------------------------o0o-
while (1) {
    //-o0o- Lecture du fichier ip.php se trouvant sur le site de    -o0o-
    //-o0o- Free qui va nous renvoyer $_SESSION['REMOTE_ADDR']        -o0o-
    //-o0o-----------------------------------------------------------o0o-
    $adresse_ip = "";
    if ( $id_fic = @fopen("http://login.free.fr/ip.php",'rb')) {
        if ($id_fic) {
            while(!feof($id_fic)) {
                $adresse_ip .= fread($id_fic,16);
            }
                                                fclose($id_fic);
        }                
    }
    if ($id_fic) {
        if ($old_adresse != $adresse_ip) {
            //-o0o- Nouvelle adresse IP => Création d'une nouvelle page    -o0o-
            //-o0o- de redirection pour le serveur Free avec nouvelle     -o0o-
            //-o0o- adresse IP                                            -o0o-
            //-o0o-------------------------------------------------------o0o-
            $source_file    = "temp";
            echo date("F j, Y, g:i a")." : Nouvelle adresse IP : ".$adresse_ip." \n";
            if ( $id_fic = fopen($source_file,'wb')) {
                echo "Fichier ".$source_file." ouvert : ".$id_fic." \n";
                $contenu = "<?php \n";
                $contenu .= "    if (! @fopen('http://".$adresse_ip."/ALIAS_SITE_SI_Y_EN_A_1/', 'r')) { \n";
                $contenu .= "        header('Location: hs.php'); \n";
                $contenu .= "    } else { \n";
                $contenu .= "        header('Location: http://".$adresse_ip."/ALIAS_SITE_SI_Y_EN_A_1/'); \n";
                $contenu .= "    } \n";
                $contenu .= "?";
                $contenu .= "> \n";
    //            echo "Contenu de la page : \n";
    //            echo $contenu;
                if (fwrite($id_fic,$contenu,strlen($contenu))) {
                    fclose($id_fic);
                    echo "Fichier temporaire OK \n";
                    
                    //-o0o- le fichier temporaire a été correctement créé    -o0o-
                    //-o0o- Envoi par FTP sur le serveur de Free            -o0o-
                    //-o0o---------------------------------------------------o0o-
                    echo "Ouverture connection FTP \n";
                    
                    //-o0o- Paramètre de connection                            -o0o-
                    //-o0o---------------------------------------------------o0o-
                    $ftp_server         = "ftpperso.free.fr";
                    $ftp_user_name        = "login";
                    $ftp_user_pass        = "password";
                    $destination_file    = "index.php";
                    
                    $conn_id = ftp_connect($ftp_server); 
                    $login_result = ftp_login($conn_id, $ftp_user_name, $ftp_user_pass); 
                    if ((!$conn_id) || (!$login_result)) { 
                       echo "La connection FTP a échouée ! \n";
                       echo "Tentative de connection au server".$ftp_server."pour l'utilisateur".$ftp_user_name." \n";
                       exit; 
                    } else {
                        echo "Connection réussie \n";
                    }
                    $upload = ftp_put($conn_id, $destination_file, $source_file, FTP_BINARY); 
                    if (!$upload) { 
                        echo "Echec de l'Upload du fichier ! \n";
                    } else {
                        echo "Fichier envoyé avec succès. \n";
                    }
                    ftp_close($conn_id);
                    
                    //-o0o- Tout s'est déroulé correctement => suppression    -o0o-
                    //-o0o- du fichier temporaire et mémorisation de la     -o0o-
                    //-o0o- nouvelle adresse IP                                -o0o-
                    //-o0o---------------------------------------------------o0o-
                    unlink($source_file);
                    $old_adresse = $adresse_ip;
                } else
                {
                    echo "Erreur d'écriture dans le fichier temporaire \n";
                }
            }
        }
    }
    //-o0o- Attente de 10 minutes                                        -o0o-
    //-o0o---------------------------------------------------------------o0o-
    sleep(3000);
}
?>
 
comme je l'ai écris plus haut je débute sur PHP alors il est possible qu'il y ai quelques petits soucis mais chez moi ça a l'air de fonctionner correctement

il reste plus qu'à lancer un raccourcis qui exécute la commande php -f redirection_free.php (racourcis qui sera créé sur son bureau) pour lancer la redirection automatique.

et ainsi je peux avoir une connection sur mon PC en tapant l'adrese http://login.free.fr sans avoir à connaître mon IP

Dernière modification par Yogui ; 30/04/2006 à 14h01.
Leviathan_72 est déconnecté   Envoyer un message privé Réponse avec citation
Vieux 11/08/2005, 14h40   #7
Invité régulier
 
Date d'inscription: juin 2005
Âge: 26
Messages: 19
Envoyer un message via MSN à HuZimA
Par défaut

delete...

Dernière modification par HuZimA ; 11/12/2009 à 16h04.
HuZimA est déconnecté   Envoyer un message privé Réponse avec citation
Vieux 29/08/2005, 19h04   #8
Invité régulier
 
Date d'inscription: juin 2002
Messages: 12
Par défaut

Ceci est une class pour lister un repertoire ainsi que tous ses sous repertoires et les fichiers d'une manièere assez "organisée"

Code :
class folder_recursive
{
	function folder_recursive (&$array, $path = './')
	{
		if (!is_dir ($path))
			return FALSE;
 
		if (!is_array ($array)) 
			$array = array ();
 
		$dir = @opendir ($path);
 
		while ($res = @readdir ($dir))
		{
			if (($res == '.') || ($res == '..'))
				continue;
 
			if (is_file ($path.$res)) 
			{
				$exp = explode ('/', $path);
				array_pop ($exp);
 
				$len = count ($exp);
 
				for ($i = 0; $i < $len; ++$i) 
					$exp[$i] .= '/';
 
				$this->array_dim ($array, $exp, $res);
			}	
 
			elseif (is_dir($path.$res.'/')) 
				$this->folder_recursive($array, $path.$res.'/');
		}
 
		@closedir($dir);
 
		return TRUE;
	}
 
	function array_dim (&$array, $dim, $value, $key = NULL)
	{
		if (!is_array ($dim)) 
			return FALSE;
 
		$string = '$array';
 
		foreach ($dim as $key_ => $value_) $string .= '[\''.$this->quoteslashes ($value_).'\']';
 
		$string .= ($key === NULL) ? '[]' : '[\''.$this->quoteslashes ($key).'\']';
 
		$string .= ' = \''.$this->quoteslashes ($value).'\';';
 
		if ($this->is_err ($string))
			return FALSE;	
		else
			eval ($string);
 
		return TRUE;
	}
 
	function quoteslashes ($string)
	{
		return str_replace ('\'', '\\\'', $string);	
	}
 
	function is_err ($expr)
	{
		$err = @ini_get ('error_reporting');
		error_reporting (E_ALL);
 
		ob_start ();
		eval ($expr);
		$str = ob_get_contents ();
		ob_end_clean ();
 
		error_reporting ($err);
 
		return (strlen($str) != 0);
	}
}
Pour l'utiliser

Code :
$a = array ();
 
$obj = new folder_recursive ($a, './');
 
echo '<pre>', print_r ($a), '</pre>';
Dozer est déconnecté   Envoyer un message privé Réponse avec citation
Vieux 29/09/2005, 11h36   #9
Futur Membre du Club
 
Date d'inscription: juillet 2004
Messages: 33
Par défaut

Proposer de récupérer une page web en PDF

Nécéssaire :
htmldoc d'installé sur un serveur unix/linux

A remplir :
Code :
 
$racine = "chemin par rapport à la racine du site";
$chemin = "de l'image du logo PDF";
 
La fonction à intégrer:
Code :
 
function GenererPDF($contenu){
	global $racine;
	global $skin;
 
	// Formulaire de demande de PDF
	if (empty($_POST['PDF'])){
		echo $contenu; 
		echo "  <form action=\"".$_SERVER['PHP_SELF']."\" name=\"Genpdf\" method=\"POST\">
		        <input type=\"submit\" name=\"PDF\" value=\"PDF\" align=\"left\">
			</form>";
	}else{ 
	
		// Vérification/création du cache
		// mise en place d'un accès total à ce repertoire
		if (!file_exists($_SERVER['DOCUMENT_ROOT']."/cache"))
		{
			exec("mkdir ".$_SERVER['DOCUMENT_ROOT']."/cache | chmod 777 ".$_SERVER['DOCUMENT_ROOT']."/cache");
			echo "Le dossier de Cache a bien été créé";
		}
		// Si les droits sur le dossier ont changé on tente de les remettre (www-data doit être proprio du dossier)
		if (substr(sprintf('%o', fileperms($_SERVER['DOCUMENT_ROOT'].'/cache')), -4) !== "777")
		{
			$anciendroit = substr(sprintf('%o', fileperms($_SERVER['DOCUMENT_ROOT'].'/cache')), -4);
			exec("chmod 777 ".$_SERVER['DOCUMENT_ROOT']."/cache");
			echo "Les droits sur le dossier cache ont changés (mis à ".$anciendroit."), ils ont donc été remis à 777";
		}
		
		// Création d'un nom de fichier 
		$nomfichier = ereg_replace(".php","",$_SERVER['PHP_SELF']);
		$nomfichier = substr_replace($nomfichier,"",0,1);
		$nomfichier = ereg_replace("/","_",$nomfichier);
		$nomfichier = ereg_replace(" ","",$nomfichier);
		$nomfichier = strtr($nomfichier,"àáâãäåçèéêëìíîïñòóôõöøùúûüý","aaaaaaceeeeiiiinoooooouuuuy");
 
	
		// Nettoyage de printemps
		if (file_exists($_SERVER['DOCUMENT_ROOT']."/cache/".$nomfichier.".txt"))
		{
			exec("rm ".$_SERVER['DOCUMENT_ROOT']."/cache/".$nomfichier.".txt"); 
		}
		if (file_exists($_SERVER['DOCUMENT_ROOT']."/cache/".$nomfichier.".pdf"))
		{
			exec("rm ".$_SERVER['DOCUMENT_ROOT']."/cache/".$nomfichier.".pdf"); 
		}
	
		// Copie du code HTML -> /cache
		$fp = file($_SERVER['DOCUMENT_ROOT']."/cache/".$nomfichier.".txt");
		if ( $fp = fopen($_SERVER['DOCUMENT_ROOT']."/cache/".$nomfichier.".txt", "w+") )
		{
			fwrite( $fp, $contenu); 
		}else{
			echo "Le PDF n'a pas pu être généré : Erreur à la création du fichier temporaire";
		}
		fclose($fp);            
		sleep(1);
		
              // Appel de HTMLDOC pour generer le PDF
               $sortie = exec('htmldoc -t pdf --quiet  --jpeg=90  --webpage '.$_SERVER['DOCUMENT_ROOT'].'cache/'.$nomfichier.'.txt -f '.$_SERVER['DOCUMENT_ROOT'].'cache/'.$nomfichier.'.pdf',$tableau,$retour);
   
               if($retour == 0) 
		{
			echo "\n Veuillez patienter génération de votre PDF.....";
			sleep(2);
			echo "\n <br><br><a href='".$racine."cache/".$nomfichier.".pdf'>";
			echo "	<img src='".$skin."' alt='Télécharger ".$nomfichier.".pdf' border='0' width='40'>";
			echo "	Télécharger ".$nomfichier.".pdf</a>";
 
			// On supprime le fichier temporaire .txt
			if (file_exists($_SERVER['DOCUMENT_ROOT']."/cache/".$nomfichier.".txt"))
			{
				exec("rm ".$_SERVER['DOCUMENT_ROOT']."/cache/".$nomfichier.".txt"); 
			}
		}else{
	 		echo "Le PDF n'a pas pu être généré: Erreur pendant la création du PDF";
		}
	}
}
 
dans les pages web où vous voulez créer du PDF vous encadrer le code PHP de ces balises
Code :
 
 ob_start();
 
et par
Code :
 
 $contenu = ob_get_contents();
ob_end_clean();
 
et vous mettez ensuite ceci où vous voulez que le bouton générer un PDF apparaisse
Code :
GenererPDF($contenu);
saint-pere est déconnecté   Envoyer un message privé Réponse avec citation
Vieux 16/11/2005, 10h12   #10
Membre habitué
 
Avatar de thanathz
 
Date d'inscription: mars 2002
Messages: 152
Envoyer un message via ICQ à thanathz Envoyer un message via AIM à thanathz Envoyer un message via Yahoo à thanathz
Par défaut

Voici une class générant des graphiques.

Ca se trouve ici:
http://nbacenter.free.fr/tools/grafik.zip

avec une page de téléchargement des divers doc (comme par exemple les webservices et SOAP pour PHP) c'est sur http://nbacenter.free.fr/tools

et on peut pour l'instant générer trois types de graphiques: les courbes et les camemberts et histogrammes.

Le seul format supporté pour l'instant est le png et gif et jpg.

reste encore un petit bug (qui n'existe pas en local sur l'histogramme...)

Passage à la version 1.0a. Correction de nombreux bugs.
Prochaine étape, le mixage des graphiques (notament: histogramme et courbes)

exemple de courbes:



exemple de camemberts:


Et les histogrammes:


Je modifierais au fur et à mesure des évolutions ce post.

Dernière modification par Kerod ; 15/09/2006 à 00h13. Motif: Ajouté page Sources
thanathz est déconnecté   Envoyer un message privé Réponse avec citation
Vieux 26/11/2005, 14h17   #11
Membre Expert
 
Date d'inscription: juillet 2004
Messages: 1 046
Par défaut

SECONDE CLASSE DE PAGINATION

Salut,

Suite à la classe de pagination de Moloch je poste la mienne qui pour le coup se détache des requetes et est plus simple à porte sur les projets ( efin je pense).

A vous de juger de toute facon

Code :
 
<?
class Pagination{
 
    var $URL;                            // URL du lien
    var $NomVar;                        // Nom de la variable indiquant la page courante
    var $Nombre;                        // Nombre de pages à afficher
    var $Class;                            // Class à utiliser pour les liens
    var $Total;                            // Nombre d'éléments total (les éléments qui sont paginés)
    var $SelectedClass;                // Class à utiliser pour la page actuellement selectionnée
    var $SelectedPage;                // Numéro de la page selectionnée
    var $CaractereDespacement;        // Définit le cractères qui sépares chaque page
    var $ShowPreview;                    // Définit si précédents doit TOUJOURS être afficher
    var $TextPreview;                    // Texte à afficher pour le bouton précédent
    var $TextNext;                        // Texte à afficher pour le bouton suivant
    var $TextPrevGroup;                // Texte à afficher pour le bouton groupe précédent
    var $TextNextGroup;                // Texte à afficher pour le bouton groupe suivant
    
    /* PRIVATE :: inutile de la modifier */
    var $Debut;                            // Page à laquelle débute l'actuel pagination
 
    function __construct(  )
    {
        $this->URL                            = "";
        $this->NomVar                        = "";
        $this->Debut                        = "";
        $this->Nombre                        = "";
        $this->Class                        = "";
        $this->Total                        = 0;
        $this->SelectedClass                = "";
        $this->SelectedPage                = 0;
        $this->Reponse                        = "";
        $this->ShowPreviewAndNext        = true;
        $this->CaractereDespacement     = "";
        $this->TextPreview                 = "&lt;";
        $this->TextNext                     = "&gt;";
        $this->TextPrevGroup             = "&lt;&lt;";
        $this->TextNextGroup             = "&gt;&gt;";
    }
 
    function Pagine(  )
    {
        $reponse                 = "";
        $this->SelectedPage     = $this->SelectedPage     == "" ? 0 : intval($this->SelectedPage);
        $this->Nombre             = $this->Nombre             == "" ? 0 : intval($this->Nombre);
        $this->Total             = ceil ($this->Total);
 
        if($this->Total < 1 )
        {
            return false;
        }
        
        
        $this->DefineInterval( );
        
        if($this->Debut < $this->Nombre )
        {
            $this->Debut = 0;
        }
        
        if($this->Debut >= $this->Nombre )
        {
            $reponse = "<a href=\"".$this->URL."&".$this->NomVar."=".($this->Debut-$this->Nombre)."\" class=\"".$this->Class."\" >".$this->TextPrevGroup."</a>&nbsp;&nbsp;";
        }
        elseif ( $this->ShowPreviewAndNext == true) 
        {
            $reponse = "<a class=\"".$this->SelectedClass."\" >".$this->TextPrevGroup."</a>&nbsp;&nbsp;";
        }
        
        if( ($this->SelectedPage-$this->Debut) > 0 )
        {
            //$url = str_replace(".html" , "-".$this->NomVar."-".($this->SelectedPage-1).".html" , $this->URL);
            $reponse .= "<a href=\"".$this->URL."&".$this->NomVar."=".($this->SelectedPage-1)."\" class=\"".$this->Class."\" >".$this->TextPreview."</a>&nbsp;&nbsp;";
        }
        else
        {
            $reponse .= "<a class=\"".$this->SelectedClass."\" >".$this->TextPreview."</a>&nbsp;&nbsp;";
        }
        
        if( ($this->Nombre + $this->Debut) > $this->Total )
        {
            $this->Nombre = $this->Total - $this->Debut;
        }
        
        for($ii=0,$i=$this->Debut; $i < $this->Debut+$this->Nombre; $i++)
        {    
            $ii = $i > 8 ? $i+1 : "0".($i+1);
            if( $i == $this->SelectedPage )
            {
                $reponse .= "<a class=\"".$this->SelectedClass."\" >".$ii."</a>".$this->CaractereDespacement;
            }
            else
            {
                //$url = str_replace(".html" , "-".$this->NomVar."-".$i.".html" , $this->URL);
                $reponse .= "<a href=\"".$this->URL."&".$this->NomVar."=".$i."\" class=\"".$this->Class."\" >".$ii."</a>".$this->CaractereDespacement;
            }
        }
 
        if( ($this->Debut+$this->Nombre)-$this->SelectedPage > 1 )
        {
            $reponse = substr ( $reponse, 0 , ( strlen($reponse) - strlen($this->CaractereDespacement) )  );
            //$url = str_replace(".html" , "-".$this->NomVar."-".($this->SelectedPage+1).".html" , $this->URL);
            $reponse .= "&nbsp;<a href=\"".$this->URL."&".$this->NomVar."=".($this->SelectedPage+1)."\" class=\"".$this->Class."\" >".$this->TextNext."</a>&nbsp;";
        }
        else
        {
            $reponse = substr ( $reponse, 0 , ( strlen($reponse) - strlen($this->CaractereDespacement) )  );
            $reponse .= "&nbsp;<a class=\"".$this->SelectedClass."\" >".$this->TextNext."</a>&nbsp;";
        }
        
        if( ($this->Debut + $this->Nombre) < ( $this->Total ) )
        {
            //$url = str_replace(".html" , "-".$this->NomVar."-".($this->Debut+$this->Nombre).".html" , $this->URL);
            $reponse .= "&nbsp;<a href=\"".$this->URL."&".$this->NomVar."=".($this->Debut+$this->Nombre)."\" class=\"".$this->Class."\" >".$this->TextNextGroup."</a>";
        }
        elseif ( $this->ShowPreviewAndNext == true) 
        {
            $reponse .= "&nbsp;<a class=\"".$this->SelectedClass."\" >".$this->TextNextGroup."</a>";
        }
        else
        {
            $reponse = substr ( $reponse, 0 , ( strlen($reponse) - strlen($this->CaractereDespacement) )  );
        }
        
        if($reponse != "")
        {
            $this->Reponse = $reponse;
            return true;
        }
        
        return false;
    }
    
    function DefineInterval( )
    {
        $this->Debut = $this->Nombre * floor ($this->SelectedPage / $this->Nombre ) ;
    }
    
}
 
?>
<? 
$_GET["debut"] = isset($_GET["debut"])?$_GET["debut"]:0;
$Pages                             = new Pagination();
$Pages->URL                     = "index.php?var=1";
$Pages->NomVar                    = "debut";
$Pages->Nombre                    = 5;
$Pages->Class                    = "LienPages";
$Pages->SelectedClass            = "LienPagesSelected";
$Pages->SelectedPage            = $_GET["debut"];
$Pages->Total                    = 150/15;
$Pages->CaractereDespacement    = "&nbsp;";
/* A vous de le changer ! */
$Pages->TextPreview    = "TextPreview";
$Pages->TextNext    = "TextNext";
$Pages->TextPrevGroup    = "TextPrevGroup";
$Pages->TextNextGroup    = "TextNextGroup";
if($Pages->Pagine() == true)
{
echo $Pages->Reponse;
} 
else
{
echo "pas de pages ";
}
?>
}
?>
Petite not tout de même, le script présuppose que vous avez déja des variables dans l'url, c a d qu'il construit l'url en supposant que l'url est de la forme http://sdflkjsdlfjds.com?var=valeur

Il rajoute à la suite sa variable sous la forme &debut=15.

Fin bref vaut mieux le tester pour comprendre la limite à ce sujet.

Bye tlm

epox

Dernière modification par Yogui ; 30/04/2006 à 14h01.
ePoX est déconnecté   Envoyer un message privé Réponse avec citation
Vieux 28/11/2005, 09h40   #12
Nouveau membre du Club
 
Date d'inscription: janvier 2005
Messages: 63
Par défaut

Toujours dans les barre de navigation, laissez moi vous présenter la mienne que je trouvre vraiment plus simple :

elle permat de rechercher des informations dans une bases de données en limitant l'affichage du nombre de résultat de la page à dix.


Code :
 <?php
//si un numero de page est envoyé on le récupère et on met à jour les limites d'affichage
if(isset($_GET['page']))
{
    $Page = $_GET['page']-1;
    if($Page == 0)
    {  
        $debut = 0;
        $fin = 10;
    }
    else
    {
        $debut = ($Page * 10);
        $fin = $debut + 9;
    }
}
else
{
    //sinon ça correspond aux 10 premières lignes de la recherche
    $debut = 0;
    $fin = 10;
}
//nombre de résultats par page
$maxRows_RechercheClient = 10;
//requete qui selectionne les clients dont le nom correspond aux données saisies
$query_RechercheClient = "SELECT NumClient,NomClient  FROM WHERE nomccli LIKE '%$recherche%' Order by NumClient LIMIT $debut,$fin ";
$RechercheClient = mysql_query($query_limit_RechercheClient) or die(mysql_error());
$row_RechercheClient = mysql_fetch_assoc($RechercheClient);
 
//determine le nombre total de pages
if (isset($_GET['totalRows_RechercheClient'])) 
{
     $totalRows_RechercheClient = $_GET['totalRows_RechercheClient'];
} 
else 
{
$all_RechercheClient = mysql_query($query_RechercheClient);
    $totalRows_RechercheClient = mysql_num_rows($all_RechercheClient);
}
$totalPages_RechercheClient = ceil($totalRows_RechercheClient/$maxRows_RechercheClient); 
$i=0;
// ---------- Afficher le tableau de résultat--------    
 
    
//si j'ai au moins une page de résultats            
if($totalPages_RechercheClient >1)
{    
for ($j =1; $j<= $totalPages_RechercheClient; $j++) 
{  
    // Affiche la barre de navigation
    echo "<a href = '".$cible."?page=$j&recherche=".$recherche."'>$j</a> ";
} 
}

Dernière modification par Eric Berger ; 28/06/2006 à 00h19.
dinde est déconnecté   Envoyer un message privé Réponse avec citation
Vieux 30/11/2005, 00h46   #13
Membre Expert
 
Date d'inscription: juillet 2004
Messages: 1 046
Par défaut

Salut,

je trouvais cette petite classe de benchmark tellement pratique que je me la suis réadaptée vite fait pour mes projets.

C'est pas mieux, ni différent, c'est juste plus maléable au niveau de la sortie.

bref vu que j'ai tout pompé je vais pas me priver de la remettre pour qui veut.

en tout cas bien vu genova et thanathz

Bye

Code :
 
<? 
class Benchmark 
{ 
   
   private $Marks; 				// Contient les différents temps pour les étapes 
   private $TimeEnd; 			// Temps final 
   private $TimeStart; 			// Temps de départ
   private $TotalChanged;		// Indique si le total doit etre reclaculé
   private $Total_;				// Indique si le total doit etre reclaculé
 
   /* 
   ** Constructeur de la classe bench. 
   ** Initialise le temps de départ. 
   */ 
   public function __construct() 
   { 
      $this->TimeStart 		= 0; 
      $this->TimeEnd 		= 0; 
	  $this->Total_			= 0;
      $this->Marks 			= array(); 
      $this->TotalChanged 	= false; 
	  
      $this->TimeStart 	= microtime(true); 
   }
 
   /* 
   ** Créé un marqueur qui retient le temps écoulé. 
   */ 
   public function addMark( $Nom , $Commentaire )
   {
		$Mark = new Mark( $Nom , $Commentaire );
		array_push($this->Marks , $Mark);
		$this->TotalChanged 	= true; 
   } 
   
   
   public function StopLastAddedMark( )
   {
      $Mark = $this->Marks[count($this->Marks)-1]->Stop();
   }
   
   public function __get( $prop )
   {
   		switch( $prop )
		{
			case "Total":
				if( $this->TotalChanged )
				{
					$this->Total_ = 0;
					for($i=0 , $ii=count($this->Marks);$i<$ii; $i++)
					{
						$this->Total_ += $this->Marks[$i]->Duree;
					}
					$this->TotalChanged = false;
					return $this->Total_;
				}
				else
				{
					return $this->Total_;
				}
			break;
			case "Duree":
				$this->TimeEnd = $this->TimeEnd == 0 ? microtime(true) : $this->TimeEnd;
				return $this->TimeEnd-$this->TimeStart;
			break;
			case "TimeStarted":
				return date("H:i:s",$this->TimeStart);
			break;
			case "TimeEnded":
				return date("H:i:s",$this->TimeEnd);
			break;
			case "Items":
				return $this->Marks;
			break;
		}
   }
   
   public function Stop ( )
   {
   		$this->TimeEnd = microtime(true); 
   }
}
 
class Mark
{
	public $TimeStart;
	public $TimeEnd;
	public $Nom;
	public $Commentaires;
	
	public function __construct( $Nom , $Commentaire )
	{
		$this->TimeStart 		= 0;
		$this->TimeEnd 			= 0;
		$this->Nom 				= $Nom;
		$this->Commentaires 	= $Commentaire;
		
		$this->TimeStart 		= microtime(true); 
	}
	
	public function __get( $prop )
	{
		switch( $prop )
		{
			case "Duree":
            $this->TimeEnd = $this->TimeEnd == 0 ? microtime(true) : $this->TimeEnd;
            return $this->TimeEnd-$this->TimeStart < 0 ? 0 : $this->TimeEnd-$this->TimeStart;
			break;
			case "TimeStarted":
				return date("H:i:s",$this->TimeStart);
			break;
			case "TimeEnded":
				return date("H:i:s",$this->TimeEnd);
			break;
		}
	}
   
   public function Stop ( )
   {
   		$this->TimeEnd = microtime(true); 
   }
}
 
 
//*****************************************************************************************
// APPLI TEST
//*****************************************************************************************
$Yop = new Benchmark();
usleep(2000000);
$Yop->addMark( "+2" , "Stopper à +8" );
usleep(2000000);
$Yop->addMark( "+4" , "Stopper à +10" );
usleep(2000000);
$Yop->addMark( "+6" , "Stopper à +12" );
usleep(2000000);
$Yop->Items[0]->Stop();
usleep(2000000);
$Yop->Items[1]->Stop();
usleep(2000000);
$Yop->Items[2]->Stop();
usleep(2000000);
$Yop->Stop();
 
echo "<div style=\"font-family:Arial;\">";
echo "Debuter à ".$Yop->TimeStarted;
echo "<br/>";
	for( $i =0; $i < count($Yop->Items); $i++ )
	{
		echo "&nbsp;&nbsp;&nbsp;&nbsp; Nom : ";
		echo "<strong>".$Yop->Items[$i]->Nom."</strong>";
		echo "<br/>";
		echo "&nbsp;&nbsp;&nbsp;&nbsp; Commentaires :";
		echo "".$Yop->Items[$i]->Commentaires."";
		echo "<br/>";
		echo "&nbsp;&nbsp;&nbsp;&nbsp; Debuter à ";
		echo "".$Yop->Items[$i]->TimeStarted."";
		echo "<br/>";
		echo "&nbsp;&nbsp;&nbsp;&nbsp; Fini à ";
		echo "".$Yop->Items[$i]->TimeEnded."";
		echo "<br/>";
		echo "&nbsp;&nbsp;&nbsp;&nbsp; A durée ";
		echo "".$Yop->Items[$i]->Duree." secondes";
		echo "<br/>";
		echo "&nbsp;&nbsp;&nbsp;&nbsp; Pourcentage du total ";
		echo "".round(($Yop->Items[$i]->Duree/$Yop->Total)*100)." % ";
		echo "<br/>";
		echo "&nbsp;&nbsp;&nbsp;&nbsp; ---------------------------------------------------------------------------------";
		echo "<br/>";
	}
echo "Fini à ".$Yop->TimeEnded;
echo "<br/>";
echo "A durée : ".$Yop->Duree." secondes";
echo "<br/>";
echo "</div>";
?> 
 
ePoX est déconnecté   Envoyer un message privé Réponse avec citation
Vieux 07/12/2005, 10h43   #14
Membre à l'essai
 
Date d'inscription: novembre 2005
Messages: 40
Par défaut

Nom de la classe : mysqlHelper
Configuration requise : PHP 5 et mySQL >= 4.0.25
Propriétés :
  • Connection/Deconnection à une base mysql
  • Récupération liste des bases d'une serveur, des tables d'une base, des champs et index d'une table
  • Permet d'exporter une base de donnée sans l'utilitaire mysqldump.exe
  • Exporte la strucutre complète d'une base sous format XML
  • Permet de répliquer une base de donnée maître vers N bases de donnée esclaves
Réplication : J'ai créé cette fonction car je suis en hébergement mutualisé sans accès aux fonctions de réplication de mySQL ni aux fichiers de logs de mySQL.
Pour le moment, elle permet de répliquer les :
  • Ajout/Modification/suppression de tables
  • Ajout/Modification/suppression de champs
  • Ajout/Modification/suppression d'index
  • Contenus de certaines tables (paramétrées dans un fichier de config)
Remarques : Cette version ne tient pas compte des nouveautés des mySQL 5 (je n'ai pas accès à cette version pour le moment).
Contenu du fichier :
  • La classe
  • Un exemple de fichier de config pour al réplication
  • Un fichier d'exemples
Lien:mysqlHelper

Dernière modification par Kerod ; 15/09/2006 à 00h15. Motif: Ajouté page Sources
ankou2005 est déconnecté   Envoyer un message privé Réponse avec citation
Vieux 19/12/2005, 13h30   #15
Inscrit(e)
 
Avatar de Caerbannog
 
Date d'inscription: novembre 2004
Messages: 207
Par défaut

Remplacement de glob()
Free (comme d'autre hébergeurs) a désactivé la fonction Glob() à cause d'une faille. En plus elle retourne NULL et on peut pas en faire une du même nom !
Voici comment l'émuler :
Code :
<?
// (C) Caerbannog 2005
if(glob("doYouExist?") == NULL) {
     function free_glob($path) {
          $result = Array();
          $index = 0;
          preg_match("#^(.*/)?([^/]*)$#", $path, $matches);
          list(, $dir, $path) = $matches;
          $path = "#" . str_replace(Array("\\", ".", "[", "]", "?", 
                                          "+", "(", ")", "#", "*"),
                                    Array("\\\\", "\\.", "\\[", "\\]", "\\?",
                                          "\\+", "\\(", "\\)", "\\#", "([^/]*)"),
                                    $path) . "#";
          if($dir == '')
               $handle = opendir('.');
          else
               $handle = opendir($dir);
          while($file = readdir($handle)) {
               if($file == '..' || $file == '.')
                    continue;
               if(preg_match($path, $file)) {
                    if(is_file($dir . $file)) {
                         $result[$index] = $dir . $file;
                         $index++;
                    }
               }
          }
          closedir($handle);
          return $result;
     }
}
?>
Plus de fonctions de Free émulées.
Caerbannog est déconnecté   Envoyer un message privé Réponse avec citation
Vieux 27/12/2005, 10h47   #16
Membre du Club
 
Date d'inscription: décembre 2005
Messages: 97
Par défaut

desolé, je n'ai pas de FTP disponible pour mettre un lien vers un ZIP.

cette classe permet d'exploiter le webservice de cartographie michelin.

"l'api" fournie etant franchement super naze , des fonctions avec 40 arguments a passer, des variables tableaux a 50dimensions, des resultats mis en session, des variables passées par réference ( et si le serveur est configuré pour ne pas accepter... )

j'ai donc fais ma classe ( qui se veut simple d'utilisation ) pour exploiter sans avoir 2000arguments a passer a chaque fonction...
( et aussi pour avoir quelque chose d'OO, parce-que ça deviens vite tres brouillon )

REQUIERT :
-la classe NUSOAP
-le fichier de constantes michelin ( fournit sur le site ws.viamichelin.com)

Classe Adresse / AdresseList ( le constructeur de la classe michelinWebService prend en parametre le tableau generé par AdresseList->toArray())
Code :
 
class Adresse
{
var $adresse;
var $cp;
var $ville;
var $pays;
	function Adresse($adresse,$ville,$cp)
	{
	$this->adresse=$adresse;
	$this->ville=$ville;
	$this->cp=$cp;
	$this->pays='FRA';
	}
	function toArray()
	{
	return array('address' => $this->adresse, 'cityName' => $this->ville, 'postalCode' => $this->cp, 'stateName' => '', 'countryCode' =>$this->pays);
	}
}
 
class AdresseList
{
var $listeAddr;
var $nbAdresse;
var $position;
	function AdresseList(){
	$this->listeAddr=Array();
	$this->nbAdresse=0;
	}
	function getAdresse($i){
	return $this->listeAddr[$i];
	}
	function add($adresse)
	{
	$this->listeAddr[]=$adresse;
	$this->nbAdresse++;
	}
	function toArray()
	{
	$array=Array();
		for($i=0;$i<$this->nbAdresse;$i++)
		{
		$array[]=$this->listeAddr[$i]->toArray();
		}
	return $array;
	}
	function print_rd()
	{
	echo '<pre>';
	print_r($this->toArray());
	echo '</pre>';
	}
}
 
Classe michelinWebService
Code :
 
 
/////////////////////////////////////////////CLASS michelinWebService\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\
//
//
//
//**************************************************EXEMPLE D'UTILISATION*******************************************
//
////////////////////////////////////// --------------------------1 Affiche une carte des deux destinations )
/*
include_once("lib/michelinWS.class.php");
include_once("lib/ViaMichelinWS_CONST.php");
include_once("lib/config.php");
 
$listeAdresse=new AdresseList();
$adresse1=new Adresse('1place des hauts tillers','Gennevillier','92230');
$listeAdresse->add($adresse1);
$adresse2=new Adresse('Boulevard Charonne','Paris','75011');
$listeAdresse->add($adresse2);
 
$michelinWS=new michelinWebService(USERNAME,PASSWORD);
$michelinWS->setItineraryType(AVOID_TOLL_ROADS_ITINERARY);
$michelinWS->getLocationsList($listeAdresse->toArray());
$michelinWS->createItiSteps();
$t=$michelinWS->getRoute();
$t=$michelinWS->getMap();
header('Content-type image/gif');
echo $michelinWS->getMapBin();
*/
/////////////////////////////////////// ------------------------2 Affiche la distance de depart a arrivée )
/*
include_once("lib/michelinWS.class.php");
include_once("lib/ViaMichelinWS_CONST.php");
include_once("lib/config.php");
 
$listeAdresse=new AdresseList();
$adresse1=new Adresse('1place des hauts tillers','Gennevillier','92230');
$listeAdresse->add($adresse1);
$adresse2=new Adresse('Boulevard Charonne','Paris','75011');
$listeAdresse->add($adresse2);
 
$michelinWS=new michelinWebService(USERNAME,PASSWORD);
$michelinWS->setItineraryType(AVOID_TOLL_ROADS_ITINERARY);
$michelinWS->setDetailsLevel(SYNTHESIS_DETAIL_LEVEL);
$michelinWS->setResponseElements(ITINERARY_TRACE_ONLY);
$llist=$michelinWS->getLocationsList($listeAdresse->toArray());
$michelinWS->createItiSteps();
$t=$michelinWS->getRoute();
$dist=$michelinWS->getDistance();
print_r($dist);*/
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
class michelinWebService
{
var $login;
var $pass;
///////variable resultantes des appels de methodes soap
var $locationList;
var $itiSteps;
var $routeCalculationResult;
var $generateMapResult;
var $distResult;
var $bestMapResult;
///////Variable composant les requetes soap
var $responseOptions;
var $presentationOptions;
var $itineraryOptions;
//////variable composant $this->presentationOptions
var $language; 
var $detailsLevel; 
var $tollCategory;
//////variable composant $this->itineraryOptions
var $itineraryType;
var $vehicleType;
var $date;
//////variable composant $this->responseOptions
var $responseElements;
var $mapDefinitionCalculated;
/////taille de la carte
var $mapPixelWidth;
var $mapPixelHeight;
 
	function michelinWebService($log,$pass)
	{
		$this->login=$log;
		$this->pass=$pass;
		//initialise les conteneurs de resultats des requetes
		$this->locationList=NULL;
		$this->itiSteps=Array();
		$this->routeCalculationResult=NULL;
		$this->generateMapResult=NULL;
		$this->distresult=NULL;
		$this->bestMapResult=NULL;
		//Taille d'une carte par defaut
		$this->mapPixelWidth=600;
		$this->mapPixelHeight=600;
		////////////////////////////initialise les variables de $responseOptions / itineraryOptions / presentationOptions\\\\\\\\\\\\\\\\\\\\\\\\\\\\
		//////variable composant $this->presentationOptions
		$this->language=French; 
		$this->detailsLevel=NORMAL_DETAIL_LEVEL;
		$this->tollCategory=CAR;
		//////variable composant $this->itineraryOptions
		$this->itineraryType=RECOMMANDED_ITINERARY;
		$this->vehicleType=LIGHT_VEHICLE;
		$this->date=date('Y-m-d\TH:i:s.Z');
		//////variable composant $this->responseOptions
		$this->responseElements=ITINERARY_TRACE_AND_ITINERARY_ROADMAP;
		$this->mapDefinitionCalculated=MAIN_MAPDEFINITION_ONLY;
		///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
		//INITIALISE des parametres utilisé pour la requete 'getRoute()' ***********
		$this->itineraryOptions = 
		array(
		'itineraryType' => $this->itineraryType, 
		'vehicleType' =>$this->vehicleType, 
		'date' =>$this->date
		);
		
		$this->responseOptions = 
		array(
		'responseElements' =>$this->responseElements,
		'mapDefinitionCalculated' =>$this->mapDefinitionCalculated,
		'mainMapWidth' => $this->mapPixelWidth, 
		'mainMapHeight' => $this->mapPixelHeight
		);
		
		$this->presentationOptions = 
		array(
		'language' => $this->language, 
		'detailsLevel' =>$this->detailsLevel, 
		'tollCategory' => $this->tollCategory
		);
		///////////////////////////////////////////////////////*************
	}
	///////////////////////////////#####################MODIFIER OPTION###############\\\\\\\\\\\\\\\\\\\\\\\\\\\\
	//////////////////////////////////////////itineraryOptions
	function setDate($d)
	{
	$this->date=$d;
	$this->reloadItineraryOptions();
	}
	function setVehicleType($type)
	{
	$this->vehicleType=$type;
	$this->reloadItineraryOptions();
	}
	function setItineraryType($ititype)
	{
	$this->itineraryType=$ititype;
	$this->reloadItineraryOptions();
	}
	function reloadItineraryOptions()
	{
		$this->itineraryOptions = 
		array(
		'itineraryType' => $this->itineraryType, 
		'vehicleType' =>$this->vehicleType, 
		'date' =>$this->date
		);
	}
	//////////////////////////////////////////responseOptions
	function setResponseElements($elem)
	{
	$this->responseElements=$elem;
	$this->reloadResponseOptions();
	}
	function setMapDefinitionCalculated($mapDef)
	{
	$this->mapDefinitionCalculated=$mapDef;
	$this->reloadResponseOptions();
	}
	///////////////////////////
	//setMapSize();
	//param : taille en largeur
	//param : taille en hauteur
	//Desc : change la taille de la carte rendue
	////////////////////////
	function setMapSize($W,$H)
	{
	$this->mapPixelWidth=$W;
	$this->mapPixelHeight=$H;
	//Reinitialise les options de reponse
	$this->reloadResponseOptions();
	}
	function reloadResponseOptions()
	{
	$this->responseOptions = 
		array(
		'responseElements' =>$this->responseElements,
		'mapDefinitionCalculated' =>$this->mapDefinitionCalculated,
		'mainMapWidth' => $this->mapPixelWidth, 
		'mainMapHeight' => $this->mapPixelHeight
		);
	}
	/////////////////////////////////////////presentationOptions
	function setDetailsLevel($ll)
	{
	$this->detailsLevel=$ll;
	$this->reloadPresentationOptions();
	}
	function setLanguage($lang)
	{
	$this->language=$lang;
	$this->reloadPresentationOptions();
	}
	function setTollCategory($cat)
	{
	$this->tollCategory=$cat;
	$this->reloadPresentationOptions();
	}
	function reloadPresentationOptions()
	{
	$this->presentationOptions = 
		array(
		'language' => $this->language, 
		'detailsLevel' =>$this->detailsLevel, 
		'tollCategory' => $this->tollCategory
		);
	}
	///////////////////////////////#################################################\\\\\\\\\\\\\\\\\\\\\\\\\\\\
	
	
	///////////////////////////////
	//getLocationsList()
	//param : variable tableau listeAdresse ex : 'address' =>>adresse, 'cityName' => ville, 'postalCode' =>cp, 'stateName' => '', 'countryCode' =>pays);
	//param2 & 3 : login password michelin WS
	//Desc : retourne une variable tableau a 4 dimension 'FindLocations[]'
	//
	//Desc FindLocations[ ] 	---> Array of found locations. Always an item by supplied address even if no locations are found.
	///////////////////////////////
	function getLocationsList($inputAddresses)
	{
	$geocodingClient=$this->getSoapClient(new wsdl(GEOCODING_WSDL));
 
	$geocodingParams = 
	array(
	'request' => array('addressesList' => $inputAddresses), 
	'check' => "$this->login|$this->pass"
	);
	
	$FindLocations = $geocodingClient->call('getLocationsList', $geocodingParams);
 
		if ($geocodingClient->fault)
		{
		echo '<h2>Fault</h2><pre>';
		print_r($FindLocations);
		echo '</pre>';
		return NULL;
		}
	$this->locationList=$FindLocations;
	return $FindLocations;
	}
	///////////////////////////////
	//fonction : getDistance()
	//Desc : Renvoie la distance en kilometre du point de depart a la derniere adresse fournie
	//Conseil : si besoin seulement distance, utiliser setResponseElements(ITINERARY_TRACE_ONLY); et setDetailsLevel(SYNTHESIS_DETAIL_LEVEL)
	///////////////////////////////
	function getDistance()
	{
	if($this->locationList==NULL)
	die('Vous devez faire appel a getLocationList($listeAdresse) avant d\'utiliser getDistance() ');
	
	$dist=0;
	$distClient=$this->getSoapClient(new wsdl(DISTANCECALCULATION_WSDL));
	$dptPoints=$this->locationList['0']['results']['0']['foundLocation']['geoCoordinates'];
	$arrivalPoints=Array();
	///construi les points d'arrivée
	for($i=1;$i<count($this->locationList);$i++)
	{
	$arrivalPoints[]=$this->locationList[$i]['results']['0']['foundLocation']['geoCoordinates'];
	}
	
	$distanceCalculationRequest = 
	array(
	'request' => array('departurePoint' => $dptPoints,'arrivalPoints' => $arrivalPoints), 
	'check' => "$this->login|$this->pass"
	);
	
	$distresult=$distClient->call('getDistances',$distanceCalculationRequest);
	if($distClient->fault)
	{
	echo '<h2>Fault</h2><pre>';
	print_r($distresult);
	echo '</pre>';
	$this->distresult=NULL;
	return NULL;
	}
	for($i=0;$i<count($distresult);$i++)
	$this->distresult[]=mkDist($distresult[$i]);
	
	return $this->distresult;
	}
	///////////////////////////////////////////
	////getTime()
	///
	///
	///Desc : retourne le temps de trajet entre point de depart et point d'arrivée
	/////////////////////////////////////////////
	function getTime()
	{
	if($this->routeCalculationResult==NULL)
	die('getRoute() doit être appelé avant getTime()');
	else return $this->routeCalculationResult['drivingDirection']['drivingTime'];// ...
	}
	
	///////////////////////////////////////////
	////getRoute()
	///
	///
	///Desc : retourne/set le resultat de l'appel a la fonction getRoute
	/////////////////////////////////////////////
	function getRoute()
	{
	////test si les fonctions necessaire ont bien étés appelées avant
	if($this->itiSteps==NULL)
	die('la fonction createItiSteps() doit être appelé avant');
	////
	$routeCalculationClient  = $this->getSoapClient(new wsdl(ROUTECALCULATION_WSDL));
	
	$routeCalculationRequest = 
	array
	(
	'itiSteps' => $this->itiSteps,
	'itineraryOptions' => $this->itineraryOptions,
	'presentationOptions' => $this->presentationOptions,
	'responseOptions' => $this->responseOptions
	);
	
	$routeCalculationParams  = 
	array
	(
	'request' => $routeCalculationRequest, 
	'check' => "$this->login|$this->pass"
	);
	$this->routeCalculationResult = $routeCalculationClient->call('getRoute', $routeCalculationParams);
		if ($routeCalculationClient->fault){
		echo '<h2>Fault getRoute()</h2><pre>';
		print_r($this->routeCalculationResult );
		echo '</pre>';
		$this->routeCalculationResult=NULL;
		return NULL;
		}
		
	return $this->routeCalculationResult;
	}
 
	///////////////////////////////////////////
	////getMap()
	///
	///
	///Desc : retourne/set le resultat de l'appel a la fonction getMap()
	/////////////////////////////////////////////
	function getMap($newMap=NULL)
	{
	if($this->routeCalculationResult==NULL)
	die('getRoute() doit être appelé avant getMap()');
	
	if($newMap!=NULL)
	$useMap=$newMap;
	else
	$useMap=$this->routeCalculationResult['drivingDirection']['mapDefinition']['scaleDefinition'];
	
	$itipart 		= base64_encode($this->routeCalculationResult['itiTrace']['binaryDesc'][0]['part']);
	$binaryDesc[] 	= array('part' => $itipart);
	$itiTrace 		= array('binaryDesc' => $binaryDesc);
 
	$generateMapClient  = $this->getSoapClient(new wsdl(GENERATEMAP_WSDL));
	
	//PERMET DE METTRe des parametres par defaut. si besoin, ajout d'une methode setMapOption(); qui modifiera $this->mapOption
	if(isset($this->mapOption))
	$option=$this->mapOption;
	else
	$option=Array('imageFormat' => FORMAT_GIF);
	
	//IDEM que mapOption
	if(isset($this->pinLogos))
	$pinLogos=$this->pinLogos;
	else
	$pinLogos=NULL;
	
	$generateMapRequest = array(
	'mapDefinition' => $useMap, 
	'options' => $option, 
	'itiTrace' => $itiTrace, 
	'pinLogos' => $pinLogos
	);
	
	$generateMapParams   = array(
	'request' => $generateMapRequest, 
	'check' => "$this->login|$this->pass");
	
	$generateMapResult = $generateMapClient->call('getMap', $generateMapParams);
	
	if ($generateMapClient->fault) {
		echo '<h2>Fault</h2><pre>';
		print_r($generateMapResult);
		echo '</pre>';
		return NULL;
	} 
	$this->generateMapResult=$generateMapResult;
	return $generateMapResult;
	}
	///////////////////////////////////////////
	////getBestMapDefinition()
	///[param : precision en métres] 
	///
	///retourne un "objet" carte "optimisé"
	//utilisé par exemple pour zoomer
	///pour que la nouvelle carte soit celle prise en compte, utilisez "reloadMap();"
	/////////////////////////////////////////////
	function getBestMapDefinition($pixelSize=NULL)
	{
	if($this->locationList==NULL)
	die('getLocationList(AdresseList) doit être appelé avant d\'utiliser cette Méthode');
	//die(phpinfo());
	$bestMapClient  = $this->getSoapClient(new wsdl(GETBESTMAPDEFINITION_WSDL));
	$locationDefinition=Array();
 
	for($i=0;$i<count($this->locationList);$i++)
	{
	$locationDefinition[] =array(
	'geoCoordinate' => 
		array(
		 'id'=>$this->locationList[$i]['results']['0']['foundLocation']['id'],
		 'latitude' => $this->locationList[$i]['results']['0']['foundLocation']['geoCoordinates']['latitude'], 
		 'longitude' => $this->locationList[$i]['results']['0']['foundLocation']['geoCoordinates']['longitude']
		 )
	 );
	}
	$mapRequest=Array(
	"pixelWidth"=>$this->mapPixelWidth,
	"pixelHeight"=>$this->mapPixelHeight,
	"locations"=>$locationDefinition
	);
 
	$mapDefinitionRequest=Array(
	"check"=>$this->login.'|'.$this->pass,
	"request"=>$mapRequest
	);
	
	$bestMapResult =$bestMapClient->call('getMapDefinition',$mapDefinitionRequest);
	
		if($bestMapClient->fault)
		{
		echo '<h2>Fault</h2><pre>';
		print_r($bestMapResult);
		echo '</pre>';
		$this->bestMapResult=NULL;
		return NULL;
		}
		if($pixelSize!==NULL)
		$bestMapResult['scaleDefinition']['pixelSize']=$pixelSize;
 
	$this->bestMapResult=$bestMapResult;
	/*echo '<pre>';
	print_r($bestMapResult);
	die();*/
	return $bestMapResult;
	}
	///////////////////////////////////////////
	////reloadMap();
	///
	///
	///Desc :Recharge une carte appres modification
	/////////////////////////////////////////////
	
	function reloadMap()
	{
		if($this->bestMapResult['scaleDefinition']!=NULL)
		$this->getMap($this->bestMapResult['scaleDefinition']);
		else
		{
		if($this->routeCalculationResult['drivingDirection']['mapDefinition']['scaleDefinition']!=NULL)
		$this->getMap($this->routeCalculationResult['drivingDirection']['mapDefinition']['scaleDefinition']);
		else
		{die('pas de definition de carte pour regenerer la carte');return false;}
		}
		return true;
	}
	///////////////////////////
	//
	//Descr : Retourne l'url de la carte pour affichage
	////////////////////////////
	function getMapUri()
	{
	if($this->generateMapResult==NULL)
	die('\'">;</pre></iframe></img></script><b>Erreur</b><br /> La carte n\'a pas été definie');
	else
	return $this->generateMapResult['url'];
	}
	///////////////////////////
	//
	//Descr : Retourne le binaire de l'image généré
	////////////////////////////
	function getMapBin()
	{
	if($this->generateMapResult==NULL)
	die('la fonction getMap doit être appelé avant');
	
	$url=$this->generateMapResult['url'];
	$toSplit=strpos($url,'/',8);//permet d'eviter les deux premiers '//'
	$domain=str_replace('http://','',substr($url,'0',$toSplit));
	$leReste=substr($url,$toSplit,strlen($url));
	/*echo $domain;
	echo '<br />'.$leReste.'<br />';
	echo $toSplit;*/
	$errno=NULL;
	$errstr=NULL;
	$sock = fsockopen ($domain, 80, $errno, $errstr, 30);
	$content=NULL;
	if (!$sock) 
	{
	echo "Une erreur s'est produite<br>\n";
	echo "Numéro d'erreur : $errno<br>\n";
	echo "Description :  $errstr<br>\n";
	}else{
	$content='';
		fputs ($sock, "GET  $leReste HTTP/1.0\r\n\r\n");
		while (!feof($sock)) {
		$content.=fgets ($sock,128);
		}
		$content=preg_replace("!^(.*\r\n)*!i","",$content);//retire les entetes HTTP
	}
	
	fclose($sock);
	return $content;
	}
	///////////////////////////
	//
	//Descr : memorise les identifiants de 'locationList' ( resultat des differents points d'etapes de dest1 a dest 2 )
	////////////////////////////
	function createItiSteps()
	{
	$this->itiSteps=Array();//Ecrase les anciennes valeurs...
	if($this->locationList==NULL)
	die('getLocationsList() doit être appelé avant createItiSteps');
 
		for($i=0;$i<count($this->locationList);$i++)
		{
			$this->itiSteps[] = 
			array
			(
			'location' => Array('id' =>$this->locationList[$i]['results']['0']['foundLocation']['id'])
			);
		}
	}
	//////////////////////////////////
	//getSoapClient()
	//
	//param : $WSDL = objet de type WSDL lib nusoap
	//
	//Descr : RENVOIE UN CLIENT SOAP
	/////////////////////////////////////
	function getSoapClient($WSDL)
	{
	$proxyhost = '';
	$proxyport = '';
	$proxyusername = '';
	$proxypassword = '';
	$spclient  = new soapclient($WSDL, true, $proxyhost, $proxyport, $proxyusername, $proxypassword);
	$err = $spclient->getError();
		if ($err)
		{
		echo '<h2>SOAP Constructor error</h2><pre>' . $err . '</pre>';
		return NULL;
		}
		else
		return $spclient;
	}
}
////////////////////////////
//Fonction javascript retranscrite en PHP du SDK de michelin
// ( utilisé pour le calcul de distance )
///////////////////////////
function mkDist($i)
{
if ($i < 101) return (closer($i,10) ." m");
if (($i > 100)&&($i < 501)) return (closer($i,50) ." m");
if (($i > 500)&&($i< 2001)) return ((round(closer($i,100)/100)/10));//KM
if (($i > 2000)&&($i < 10001)) return ((round(closer($i,500)/100)/10));//KM
if ($i > 10000) return (round(closer($i,1000)/1000));//KM
}
function closer($n,$d)
{
	$dNeg = 0;
	$dPos = 0;
	while (($n-$dNeg) % $d != 0) $dNeg++;
	while (($dPos+$n) % $d != 0) $dPos++;
	return (($dPos <= $dNeg) ? ($dPos+$n) : ($n-$dNeg));
}
 
je precise aussi que l'API de michelin ne permet pas d'exploiter le 1/4 des Webservices disponibles...
j'en ais donc rajouté, en fonction de mes besoin, mais cette classe va surement evoluer, car elle non plus n'exploite pas tout les webservices disponibles. ( notamment le PinLogo ( mettre des images par exemple, sur une ville, un parking etc..) et MapManagement )

Liens :

Michelin webservice

( le fichier de constante est dans la section "telechargement" )
NUSOAP
kichemans est déconnecté   Envoyer un message privé Réponse avec citation
Vieux 23/01/2006, 15h40   #17
Rédacteur
 
Avatar de titoumimi
 
Date d'inscription: décembre 2003
Localisation: Bételgeuse
Âge: 29
Messages: 3 749
Par défaut

Créer un "chemin de fer" (suite de lien qui donne notre position dans l'arborescence du site) :

Supposons d'abord que vous avez une base de donnée avec une table pour vos pages (nommons la PAGES, parfaitement au hasard).

Supposons ensuite que dans cette table, vous auez un champ Id_page (identifiant de la page en cours, un auto increment fera très bien l'affaire), un autre appelé Id_parent (l'ID de la page parent, le N+1 dans l'organigramme), et un champ Titre (contenant le titre de votre page).

La seule règle imposée sera que l'Id_parent de la page racine sera 0.

Nous pouvons à présent passer au code :

Code :
 
function recur_chemin($idpage) {
    // on définit la variable pour éviter le warning
    $chemin_complet = "";
    // Si l'id de la page en cours est différent de 0 
    // (0 = page parente de la page racine = inexistante)
    if ($idpage != 0) {
        // on récupère les informations de la page en cours dans la DB
        $strSQL = "SELECT * FROM PAGES WHERE Id_page=".$idpage;
        $resultat = requete_SQL($strSQL);
        $tabl_result = mysql_fetch_array($resultat);
        
        $titrepage = $tabl_result['Titre'];
        $idparent = $tabl_result['Id_parent'];
        
        // création du lien vers la page en cours
        $chemin_page_en_cours = " -> <a href=\"index.php?id_p=".$idpage."\">".$titrepage."</a>";
        
        // Concaténation du lien de la page N-1 et
        // du lien de la page en cours
        $chemin_complet = recur_chemin($idparent).$chemin_page_en_cours;
    }
    //renvoie le chemin complet
    return $chemin_complet;
}
 
Il nous suffit maintenant d'appeler cette fonction à l'endroit indiqué comme suit :
Code :
 
$chemin_de_fer = recur_chemin($id_de_la_page_en_cours);
echo $chemin_de_fer;
 
J'espère que ce petit bout de script sera utile

Dernière modification par Kerod ; 15/09/2006 à 00h16. Motif: Ajouté page Sources
titoumimi est déconnecté   Envoyer un message privé Réponse avec citation
Vieux 23/01/2006, 16h08   #18
Rédacteur
 
Avatar de titoumimi
 
Date d'inscription: décembre 2003
Localisation: Bételgeuse
Âge: 29
Messages: 3 749
Par défaut

En reprenant la même structure de base que précédement, nous allons maintenant générer un plan du site sous forme de listes imbriquées, qui se mettra à jour tout seul dès que la base sera modifiée :

Code :
 
// Affiche le plan du site
// Paramètres : Id de la page en cours (0 lors du premier passage) pour lister toutes les pages filles
 
function affiche_plan_site($id_page) {
    // Sélectionne l'ensemble des pages filles de la page courante
    $strSQL = "SELECT * FROM PAGES WHERE id_parent = ".$id_page;
    $resultat = requete_SQL($strSQL);
    // Si la requête a renvoyé des résultats
    if (mysql_affected_rows() !=0) {
        echo "<ul>\n";
        // Tant qu'il y a des pages filles, on affiche un lien vers elle
        // et pour chacune d'elle, on rappelle la fonction
        while ($tabl_result = mysql_fetch_array($resultat)) {
            echo "<li>\n";
            echo "<a href=\"index.php?id_p=".$tabl_result['Id_page']."\">";
            echo $tabl_result['Titre_'];
            echo "</a>\n";
            affiche_plan_site($tabl_result['Id_page']);
            echo "</li>\n";
        }
        echo "</ul>\n";
    }
}
 

Dernière modification par Kerod ; 15/09/2006 à 00h17. Motif: Ajouté page Sources
titoumimi est déconnecté   Envoyer un message privé Réponse avec citation
Vieux 08/02/2006, 21h31   #19
Rédacteur
 
Avatar de Yogui
 
Date d'inscription: février 2004
Localisation: Yonne
Messages: 13 775
Par défaut

Script de sauvegarde de base de données volumineuse (n'importe quelle taille)


Salut à tous

Je m'occupe d'un forum phpBB et, comme tous les forums, il a fini par tellement grossir que le module de sauvegarde de la BDD inclus dans l'ACP de phpBB n'a plus suffi.
Les quelques scripts trouvés sur le Net ne me convenaient pas ou bien l'auteur en avait bridé l'usage (ce qui ne me convenait pas non plus) et je me suis dit que, au diable l'avarice, autant écrire le mien, ce serait un bon exercice de toute manière.

Je suis assez satisfait du résultat donc je vous le propose ici.
Attention, mon code est phpBB-specific, c'est-à-dire que j'utilise la classe d'astraction de BDD, l'en-tête de page, les sessions, la stratégie de sécurité et quelques tables de phpBB.
Cela dit, il ne devrait pas être trop complexe de généraliser le script si le besoin s'en faisait sentir. J'ai préféré faire ainsi pour le moment, voilà tout.

Je vous explique son fonctionnement : ce script détermine la structure des tables d'une base de données, essaie de trouver tout seul les clés primaires si elles n'existent pas (c'est parfois le cas lorsqu'il s'agit de phpBB) et les utilise pour récupérer les enregistrements.
Au fur et à mesure de la récupération des données, tout est sauvegardé dans des fichiers texte compressés.
Lorsque le timeout se rapproche ou lorsque le disque est plein, le script s'arrête de lui-même et affiche un bouton pour que l'on puisse lui dire de continuer la sauvegarde à partir d'où il en était.
Des liens sont affichés pour télécharger les archives compressées mais j'ai préféré éviter d'automatiser leur suppression, afin d'éviter les bourdes. C'est si vite fait de cocher une case trop vite et de devoir tout recommencer...

Selon ce que j'ai testé, le script fonctionne.
Cependant, afin d'éviter de se retrouver avec des incohérences dans la BDD sauvegardée, il est préférable de toujours laisser quelques Mio libres sur le FTP (ne pas attendre que le script ne puisse plus écrire), juste au cas où.


Pour installer le script, vous aurez besoin de :
  • phpBB
  • créer la table suivante (n'oubliez pas votre préfixe) :
    Code :
    CREATE TABLE `phpbb_db_backup` (
      `table_name` varchar(255) NOT NULL default '',
      `offset` int(11) NOT NULL default '0',
      PRIMARY KEY  (`table_name`)
    )
  • définir la constante qui contient le nom de la table de tracking :
    Code :
    define('BACKUP_TRACKING_TABLE', $table_prefix.'db_backup_tracking');
    cela peut être fait dans le script lui-même (au début) ou bien, et c'est ma recommandation, dans le script de phpBB qui est prévu à cet effet (habituellement /includes/constants.php)
  • copier le script dans le répertoire des scripts d'administration (habituellement dans le répertoire /admin de votre forum)
Pour l'utiliser, allez dans l'ACP et cliquez sur le nouveau lien du menu, puis suivez les instructions.

N.B. : mon pseudo habituel n'est pas Kirkis mais Yogui.

[ Télécharger le script ]

Dernière modification par Kerod ; 15/09/2006 à 00h18. Motif: Ajouté page Sources
Yogui est déconnecté   Envoyer un message privé Réponse avec citation
Vieux 13/02/2006, 14h05   #20
Membre du Club
 
Date d'inscription: avril 2004
Messages: 80
Par défaut

Parser un fichier XML avec PHP 4 et EXPAT

J'ai dû réaliser un site web il y a quelques temps, et mon hébérgeur ne disposait que de PHP 4 et d'EXPAT.
Je n'ai pas trouvé EXPAT très pratique et je voulais pouvoir utiliser mes fichiers XML un peu comme l'on m'avait appri avec Microsoft et son ActiveX XMLDOM.
Il existe des scripts pour PHP 5 (il y en a d'ailleurs un dans la FAQ) mais je n'en ai pas trouvé pour PHP 4.
Je vous présente donc celui que j'ai réalisé à l'aide du même exemple que dans la FAQ :

Le fichier parsing.php contient 2 classes : tag et XML_Parser
  • - Classe tag :
Citation:
<?php
/*** Classe gérant les balises contenues dans le fichier XML
* @param $tag_array Tableau contenant les balises filles de la balise actuelle
* @param $name Nom de la balise actuelle
* @param $data Texte éventuel dans la balise
* @param $parentTag Balise parente de la balise actuelle
* @param $attr_array Attributs éventuels de la balise actuelle
*/

class tag
{
    var 
$tag_array;
    var 
$name;
    var 
$data;
    var 
$parentTag;
    var 
$attr_array;

    
/*** Constructeur de la classe tag */
    
function tag()
    {
        
$this->tag_array = array();
        
$this->data "";
        
$this->name "";
        
$this->parentTag NULL;
    }

    
/*** Recherche la liste des balises (objets tag) contenus dans la balise désignée par le paramètre $name
    * @param $name Nom de la balise recherchée
    * @return Un tableau d'objets de type tag contenant la liste des balises parentes à la balise $name
    */
    
function getElementsByTagName($name)
    {
        
$tag_list = new tag();
        foreach (
$this->tag_array as $tag)
        {
            if(
$tag->name == $name)
            {
                
array_push($tag_list->tag_array$tag);
            }
        }
        return 
$tag_list;
    }
    
    
/*** Récupère le texte contenu entre les balises en désignant la balises concernée par son index dans un tableau d'objets tag renvoyé par 

getElementsByTagName
    * @index $index index de l'élément du tableau
    * @return Un tableau d'objets de type tag contenant la liste des balises parentes à la balise $name
    */
    
function getDataItem($index)
    {
        return 
$this->tag_array[$index]->data;
    }
    
    
/*** Retourne le nombre de balises filles de la balise actuelle
    * @return le nombre de balises filles de la balise actuelle
    */
    
function getSize()
    {
        return 
count($this->tag_array);
    }
}
?>

Phpsyntaxcolor powered by decabodi.com
  • - Classe XML_Parser :
Citation:
<?php
/*** Classe gérant le parseur XML EXPAT
* @param $xml_parser Tableau contenant les balises filles de la balise actuelle
* @param $xml_file Fichier XML à parser
* @param $root Racine du document XML
* @param $parentTag Balise parente de la balise actuelle
* @param $currentTag Balise actuellement parsée
*/

class XML_Parser
{
    var 
$xml_parser;
    var 
$xml_file;
    var 
$root;
    var 
$parentTag;
    var 
$currentTag;

    
/*** retourne un objet tag correspondant à la racine du document XML
    * @return un objet tag correspondant à la racine du document XML
    */
    
function documentElement()
    {
        return 
$this->root->tag_array[0];
    }
    
    
/*** constructeur de la classe XML_Parser */
    
function XML_Parser()
    {
        
$this->xml_parser xml_parser_create();
        
xml_set_object($this->xml_parser$this);
        
xml_set_element_handler($this->xml_parser"startTag""endTag");
        
xml_set_character_data_handler($this->xml_parser"characterData");            

        
$this->xml_file "";
        
$this->root = new tag();
        
$this->parentTag = &$this->root;
        
$this->currentTag NULL;
        }

    
/*** Destructeur de la classe XML_Parser (à appeler explicitement car PHP 4 ne gère par les destructeurs de classe) */
    
function destroy()
    {
        
xml_parser_free($this->xml_parser);
    }

    
/*** Fonction Callback appelée par le parseur XML EXPAT lors de l'ouverture d'une balise dans le fichier XML
    * @param $parser Parseur XML
    * @param $name Nom de la balise parsée
    * @param $attrs Attributs éventuels de la balise parsée
    */
    
function startTag($parser$name$attrs)
    {
        
array_push($this->parentTag->tag_array, new tag());
        
$indice count($this->parentTag->tag_array)-1;
        
$this->parentTag->tag_array[$indice]->name $name;
        
$this->parentTag->tag_array[$indice]->parentTag = &$this->parentTag;
        
$attrs?$this->parentTag->tag_array[$indice]->attr_array $attrs:0;
        
$this->parentTag = &$this->parentTag->tag_array[$indice];
        
$this->currentTag = &$this->parentTag;
            
    }

    
/*** Fonction Callback appelée par le parseur XML EXPAT lors de la fermeture d'une balise dans le fichier XML
    * @param $parser Parseur XML
    * @param $name Nom de la balise parsée
    */
    
function endTag($parser$name)
    {
        
$this->parentTag = &$this->parentTag->parentTag;
    }

    
/*** Fonction Callback appelée par le parseur XML EXPAT lors de la rencontre de texte ne correspondant par à une balise
    * @param $parser Parseur XML
    * @param $data Texte lu
    */
    
function characterData($parser$data)
    {
        
$this->currentTag->data .= $data;
    }

    
/*** Charge le fichier XML $xml_file et complète $root */
    
function load()
    {
            if (!(
$fp fopen($this->xml_file"r")))
        {
                    die(
"could not open XML input");
            }

        while (
$data fread($fp4096))
        {
            if (!
xml_parse($this->xml_parser$datafeof($fp)))
            {
                die(
sprintf("XML error: %s at line %d",
                    
xml_error_string(xml_get_error_code($this->xml_parser)),
                    
xml_get_current_line_number($this->xml_parser)));
            }
        }


    }

}
?>

Phpsyntaxcolor powered by decabodi.com
Un exemple illustrant l'utilisation à l'aide du même exemple que la FAQ (http://php.developpez.com/sources/?page=xml#parsexml)
  • - Fichier XML :
Citation:
<?xml version="1.0" encoding="ISO-8859-1"?>
<librairie>
   <livre code="15424">
      <isbn>1234567890-00-00</isbn>
      <titre>Mon premier livre</titre>
   </livre>
   <livre code="15425">
      <isbn>9876543210-00-00</isbn>
      <titre>Son second livre</titre>
   </livre>
</librairie>
Phpsyntaxcolor powered by decabodi.com
  • - exemple.php
Citation:
<?php

require("parsing.php");

$parser = new XML_Parser();
$parser->xml_file "exemple.xml";
$parser->load();
$racine $parser->documentElement();
$livres $racine->getElementsByTagName('LIVRE');

foreach(
$livres->tag_array as $livre)
{
    
$code $livre->attr_array['CODE'];
    
$isbn $livre->getDataItem(0);
    
$titre $livre->getDataItem(1);
    echo 
'<p>Code du livre : ' $code ' ISBN : ' $isbn ' Titre : ' $titre '</p>';
}

$parser->destroy();

?>

Phpsyntaxcolor powered by decabodi.com
  • - Sortie :
Citation:
<?php
Code du livre 
15424 ISBN 1234567890-00-00 Titre Mon premier livre

Code du livre 
15425 ISBN 9876543210-00-00 Titre Son second livre 
?>


Phpsyntaxcolor powered by decabodi.com
Il y a sans doute des choses à améliorer mais j'ai déjà eu l'occasion de m'en servir sur un site et ca fonctionne correctement (pour l'instant )

a+
Mayhem est déconnecté   Envoyer un message privé Réponse avec citation
NEWS PHPFAQ PHPCours PHPSources PHPLivres PHPScripts PHPOutils PHPComparatifsZend Framework

Réponse Proposer ce sujet en actualité

Précédent   Forum des professionnels en informatique > PHP > Langage > Contribuez



Outils de la discussion

Règles de messages
Vous ne pouvez pas créer de nouvelles discussions
Vous ne pouvez pas envoyer des réponses
Vous ne pouvez pas envoyer des pièces jointes
Vous ne pouvez pas modifier vos messages

Les balises BB sont activées : oui
Les smileys sont activés : oui
La balise [IMG] est activée : oui
Le code HTML peut être employé : non
Trackbacks are non
Pingbacks are non
Refbacks are non



Fuseau horaire GMT +1. Il est actuellement 03h50.


Vos questions techniques : forum d'entraide PHP - Publiez vos articles, tutoriels et cours
et rejoignez-nous dans l'équipe de rédaction du club d'entraide des développeurs francophones
Nous contacter - Hébergement - Participez - Copyright © 2000-2010 www.developpez.com - Legal informations.