|
Publicité | |||||||||||||||||||||||
|
|
#1 |
![]() Date d'inscription: septembre 2006
Localisation: 01
Messages: 6 016
|
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. |
|
|
|
|
#2 |
|
Membre émérite
![]() Date d'inscription: mars 2004
Localisation: 75013
Âge: 25
Messages: 825
|
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); ?> [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 |
|
|
|
|
|
#3 |
|
Membre émérite
![]() Date d'inscription: mars 2004
Localisation: 75013
Âge: 25
Messages: 825
|
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 !!"; } Code :
dumpMySQL("127.0.0.1", "root", "", "ma_base", 3); 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 |
|
|
|
|
|
#4 |
![]() |
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(); ?> 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. |
|
|
|
|
|
#5 |
|
Membre à l'essai
![]() |
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 |
|
|
|
|
|
#6 | |
|
Membre à l'essai
![]() Date d'inscription: juin 2004
Messages: 43
|
Script permettant à des personnes qui ont une adresse IP dynamique (non Fixe quoi
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']; ?> 3/Un script lancé en local par la commande Citation:
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); } ?> 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. |
|
|
|
|
|
|
#7 |
|
Invité régulier
![]() |
delete...
Dernière modification par HuZimA ; 11/12/2009 à 16h04. |
|
|
|
|
|
#8 |
|
Invité régulier
![]() Date d'inscription: juin 2002
Messages: 12
|
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); } } Code :
$a = array (); $obj = new folder_recursive ($a, './'); echo '<pre>', print_r ($a), '</pre>'; |
|
|
|
|
|
#9 |
|
Futur Membre du Club
![]() Date d'inscription: juillet 2004
Messages: 33
|
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"; 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"; } } } Code :
ob_start(); Code :
$contenu = ob_get_contents(); ob_end_clean(); Code :
GenererPDF($contenu); |
|
|
|
|
|
#10 |
|
Membre habitué
![]() |
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 |
|
|
|
|
|
#11 |
|
Membre Expert
![]() Date d'inscription: juillet 2004
Messages: 1 046
|
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 = "<"; $this->TextNext = ">"; $this->TextPrevGroup = "<<"; $this->TextNextGroup = ">>"; } 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> "; } elseif ( $this->ShowPreviewAndNext == true) { $reponse = "<a class=\"".$this->SelectedClass."\" >".$this->TextPrevGroup."</a> "; } 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> "; } else { $reponse .= "<a class=\"".$this->SelectedClass."\" >".$this->TextPreview."</a> "; } 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 .= " <a href=\"".$this->URL."&".$this->NomVar."=".($this->SelectedPage+1)."\" class=\"".$this->Class."\" >".$this->TextNext."</a> "; } else { $reponse = substr ( $reponse, 0 , ( strlen($reponse) - strlen($this->CaractereDespacement) ) ); $reponse .= " <a class=\"".$this->SelectedClass."\" >".$this->TextNext."</a> "; } if( ($this->Debut + $this->Nombre) < ( $this->Total ) ) { //$url = str_replace(".html" , "-".$this->NomVar."-".($this->Debut+$this->Nombre).".html" , $this->URL); $reponse .= " <a href=\"".$this->URL."&".$this->NomVar."=".($this->Debut+$this->Nombre)."\" class=\"".$this->Class."\" >".$this->TextNextGroup."</a>"; } elseif ( $this->ShowPreviewAndNext == true) { $reponse .= " <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 = " "; /* 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 "; } ?> } ?> 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. |
|
|
|
|
|
#12 |
|
Nouveau membre du Club
![]() Date d'inscription: janvier 2005
Messages: 63
|
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. |
|
|
|
|
|
#13 |
|
Membre Expert
![]() Date d'inscription: juillet 2004
Messages: 1 046
|
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 " Nom : "; echo "<strong>".$Yop->Items[$i]->Nom."</strong>"; echo "<br/>"; echo " Commentaires :"; echo "".$Yop->Items[$i]->Commentaires.""; echo "<br/>"; echo " Debuter à "; echo "".$Yop->Items[$i]->TimeStarted.""; echo "<br/>"; echo " Fini à "; echo "".$Yop->Items[$i]->TimeEnded.""; echo "<br/>"; echo " A durée "; echo "".$Yop->Items[$i]->Duree." secondes"; echo "<br/>"; echo " Pourcentage du total "; echo "".round(($Yop->Items[$i]->Duree/$Yop->Total)*100)." % "; echo "<br/>"; echo " ---------------------------------------------------------------------------------"; echo "<br/>"; } echo "Fini à ".$Yop->TimeEnded; echo "<br/>"; echo "A durée : ".$Yop->Duree." secondes"; echo "<br/>"; echo "</div>"; ?> |
|
|
|
|
|
#14 |
|
Membre à l'essai
![]() Date d'inscription: novembre 2005
Messages: 40
|
Nom de la classe : mysqlHelper
Configuration requise : PHP 5 et mySQL >= 4.0.25 Propriétés :
Pour le moment, elle permet de répliquer les :
Contenu du fichier :
Dernière modification par Kerod ; 15/09/2006 à 00h15. Motif: Ajouté page Sources |
|
|
|
|
|
#15 |
|
Inscrit(e)
Date d'inscription: novembre 2004
Messages: 207
|
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; } } ?> |
|
|
|
|
|
#16 |
|
Membre du Club
![]() Date d'inscription: décembre 2005
Messages: 97
|
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 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>'; } } 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)); } 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 |
|
|
|
|
|
#17 |
![]() Date d'inscription: décembre 2003
Localisation: Bételgeuse
Âge: 29
Messages: 3 749
|
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; } Code :
$chemin_de_fer = recur_chemin($id_de_la_page_en_cours); echo $chemin_de_fer; Dernière modification par Kerod ; 15/09/2006 à 00h16. Motif: Ajouté page Sources |
|
|
|
|
|
#18 |
![]() Date d'inscription: décembre 2003
Localisation: Bételgeuse
Âge: 29
Messages: 3 749
|
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 |
|
|
|
|
|
#19 |
![]() Date d'inscription: février 2004
Localisation: Yonne
Messages: 13 775
|
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 :
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 |
|
|
|
|
#20 | |||||
|
Membre du Club
![]() Date d'inscription: avril 2004
Messages: 80
|
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
Citation:
Citation:
Citation:
Citation:
Citation:
a+ |
|||||
|
|
|
|
|
![]() |
||
Vos meilleurs Codes Source
|
||
| Outils de la discussion | |
|
|