Précédent   Forum du club des développeurs et IT Pro > 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
 
Outils de la discussion
Publicité
'
Vieux 27/08/2003, 14h51   #1
RideKick
Rédacteur
 
Avatar de RideKick
 
Homme
Directeur technique
Inscription : septembre 2006
Messages : 5 959
Détails du profil
Informations personnelles :
Sexe : Homme
Localisation : France

Informations professionnelles :
Activité : Directeur technique
Secteur : High Tech - Produits et services télécom et Internet

Informations forums :
Inscription : septembre 2006
Messages : 5 959
Points : 13 031
Points : 13 031
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.
RideKick est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 15/09/2004, 20h13   #2
David Guillot
Membre Expert
 
Avatar de David Guillot
 
Homme David Guillot
Inscription : mars 2004
Messages : 934
Détails du profil
Informations personnelles :
Nom : Homme David Guillot

Informations forums :
Inscription : mars 2004
Messages : 934
Points : 1 015
Points : 1 015
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 :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
<?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]
__________________
Avant de poser une question ici :

Après résolution de votre question : un clic sur et un pour les personnes qui vous ont aidé
David Guillot est déconnecté   Envoyer un message privé Réponse avec citation 10
Vieux 14/10/2004, 20h37   #3
David Guillot
Membre Expert
 
Avatar de David Guillot
 
Homme David Guillot
Inscription : mars 2004
Messages : 934
Détails du profil
Informations personnelles :
Nom : Homme David Guillot

Informations forums :
Inscription : mars 2004
Messages : 934
Points : 1 015
Points : 1 015
Sauvegarder la structure et les données d'une base MySQL
Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
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]
__________________
Avant de poser une question ici :

Après résolution de votre question : un clic sur et un pour les personnes qui vous ont aidé
David Guillot est déconnecté   Envoyer un message privé Réponse avec citation 10
Vieux 07/03/2005, 01h48   #4
genova
Membre chevronné
 
Avatar de genova
 
Inscription : septembre 2004
Messages : 487
Détails du profil
Informations forums :
Inscription : septembre 2004
Messages : 487
Points : 602
Points : 602
Envoyer un message via MSN à genova
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 :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
<?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 :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
<?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 00
Vieux 09/04/2005, 11h30   #5
Antickriszt
Nouveau Membre du Club
 
Inscription : août 2004
Messages : 43
Détails du profil
Informations forums :
Inscription : août 2004
Messages : 43
Points : 34
Points : 34
Envoyer un message via MSN à Antickriszt
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é....)
Antickriszt est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 21/05/2005, 04h19   #6
Leviathan_72
Membre du Club
 
Homme Franz
Inscription : juin 2004
Messages : 43
Détails du profil
Informations personnelles :
Nom : Homme Franz
Localisation : France

Informations forums :
Inscription : juin 2004
Messages : 43
Points : 52
Points : 52
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 :
1
2
3
4
5
6
7
8
9
 
<?
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 :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
 
<?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
Leviathan_72 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 11/08/2005, 14h40   #7
HuZimA
Candidat au titre de Membre du Club
 
Inscription : juin 2005
Messages : 22
Détails du profil
Informations personnelles :
Âge : 29

Informations forums :
Inscription : juin 2005
Messages : 22
Points : 12
Points : 12
Envoyer un message via MSN à HuZimA
delete...
HuZimA est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 29/08/2005, 19h04   #8
Dozer
Invité régulier
 
Inscription : juin 2002
Messages : 12
Détails du profil
Informations forums :
Inscription : juin 2002
Messages : 12
Points : 9
Points : 9
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 :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
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 :
1
2
3
4
5
$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 00
Vieux 29/09/2005, 11h36   #9
saint-pere
Candidat au titre de Membre du Club
 
Inscription : juillet 2004
Messages : 33
Détails du profil
Informations forums :
Inscription : juillet 2004
Messages : 33
Points : 12
Points : 12
Proposer de récupérer une page web en PDF

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

A remplir :
Code :
1
2
3
 
$racine = "chemin par rapport à la racine du site";
$chemin = "de l'image du logo PDF";
La fonction à intégrer:
Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
 
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
et par
Code :
1
2
3
 
 $contenu = ob_get_contents();
ob_end_clean();
et vous mettez ensuite ceci où vous voulez que le bouton générer un PDF apparaisse
saint-pere est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 16/11/2005, 10h12   #10
thanathz
Membre habitué
 
Avatar de thanathz
 
Inscription : mars 2002
Messages : 147
Détails du profil
Informations forums :
Inscription : mars 2002
Messages : 147
Points : 120
Points : 120
Envoyer un message via ICQ à thanathz Envoyer un message via AIM à thanathz Envoyer un message via Yahoo à thanathz
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.
thanathz est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 26/11/2005, 14h17   #11
ePoX
Membre Expert
 
Inscription : juillet 2004
Messages : 1 028
Détails du profil
Informations forums :
Inscription : juillet 2004
Messages : 1 028
Points : 1 040
Points : 1 040
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 :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
 
<?
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
ePoX est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 28/11/2005, 09h40   #12
dinde
Membre du Club
 
Inscription : janvier 2005
Messages : 71
Détails du profil
Informations forums :
Inscription : janvier 2005
Messages : 71
Points : 52
Points : 52
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 :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
 <?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> ";
} 
}
dinde est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 30/11/2005, 00h46   #13
ePoX
Membre Expert
 
Inscription : juillet 2004
Messages : 1 028
Détails du profil
Informations forums :
Inscription : juillet 2004
Messages : 1 028
Points : 1 040
Points : 1 040
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 :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
 
<? 
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 00
Vieux 07/12/2005, 10h43   #14
ankou2005
Nouveau Membre du Club
 
Inscription : novembre 2005
Messages : 42
Détails du profil
Informations forums :
Inscription : novembre 2005
Messages : 42
Points : 26
Points : 26
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
ankou2005 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 19/12/2005, 13h30   #15
Caerbannog
Inscrit
 
Avatar de Caerbannog
 
Inscription : novembre 2004
Messages : 206
Détails du profil
Informations forums :
Inscription : novembre 2004
Messages : 206
Points : 201
Points : 201
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 :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
<?
// (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 00
Vieux 27/12/2005, 10h47   #16
kichemans
Membre du Club
 
Inscription : décembre 2005
Messages : 79
Détails du profil
Informations forums :
Inscription : décembre 2005
Messages : 79
Points : 42
Points : 42
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 :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
 
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 :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
 
 
/////////////////////////////////////////////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 00
Vieux 23/01/2006, 15h40   #17
titoumimi
Expert Confirmé Sénior
 
Avatar de titoumimi
 
Inscription : décembre 2003
Messages : 3 716
Détails du profil
Informations personnelles :
Âge : 32

Informations forums :
Inscription : décembre 2003
Messages : 3 716
Points : 6 016
Points : 6 016
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 :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
 
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 :
1
2
3
 
$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
titoumimi est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 23/01/2006, 16h08   #18
titoumimi
Expert Confirmé Sénior
 
Avatar de titoumimi
 
Inscription : décembre 2003
Messages : 3 716
Détails du profil
Informations personnelles :
Âge : 32

Informations forums :
Inscription : décembre 2003
Messages : 3 716
Points : 6 016
Points : 6 016
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 :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
 
// 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";
    }
}
titoumimi est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 08/02/2006, 21h31   #19
Yogui
Rédacteur
 
Avatar de Yogui
 
Homme Guillaume Rossolini
Directeur technique
Inscription : février 2004
Messages : 13 722
Détails du profil
Informations personnelles :
Nom : Homme Guillaume Rossolini
Localisation : France

Informations professionnelles :
Activité : Directeur technique

Informations forums :
Inscription : février 2004
Messages : 13 722
Points : 28 861
Points : 28 861
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 :
    1
    2
    3
    4
    5
    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 ]
Yogui est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 13/02/2006, 14h05   #20
Mayhem
Membre à l'essai
 
Inscription : avril 2004
Messages : 80
Détails du profil
Informations forums :
Inscription : avril 2004
Messages : 80
Points : 23
Points : 23
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 00
Réponse
Outils de la discussion

Navigation rapide


Fuseau horaire GMT +2. Il est actuellement 03h18.


 
 
 
 
Partenaires

Hébergement Web