Les IDN arrivent …. bientôt on devra faire attention aux accents …

IDN, késako?

IDN c’est un nouveau (enfin c’est relatif) système permettant d’utiliser des accents et des caractères non ASCII dans des nom de domaines (et sous-domaines)

La nouvelle c’est que ovh propose, en beta, l’enregistrement de tel nom de domaine et sous domaine!

Mode parano

Dans un monde ou le phishing est bien présent, je me dit que ce genre de choses est bof bof ….

En effet, rien ne sera plus simple que de créer des site au adresse avec accents pour un site qui n’en aurais pas :

  • agence de voyage : jevaislàbas.com ou jevaislabas.com ?
  • géoportail.fr ou geoportail.fr

Déjà que actuellement les gens on tendance a taper tout et n’importe quoi ….

Enfin, sinon c’est une chose merveilleuse, après tout on peux y mettre tout et n’importe quoi! exemple : ®.com, ©.com, €.net, ☎.com, ♬♬.com, ➐.com

Personnellement ,je me verrait bien créer plusieurs sous domine genre :
info.grummfy.com, avec
☎.info.grummfy.com qui retourne le numéro de téléphone
✉.info.grummfy.com pour mon email ou mon adresse

Zend Framework (ZF) : Geshi comme filtre dans ZF

Grâce à la libraire Geshi (http://qbnz.com/highlighter/) et à l’ingéniosité de ZF, colorer tout vos code, facilement, via ce nouveau filtre.

Pour l’utiliser, Télécharger la libraire geshi et décompresser là (dans l’exemple dans ./../site/lib/geshi/, donc le fichier geshi.php se trouve dans se répertoire et ./../site/lib/geshi/geshi/ contient les fichiers de langues)

<?php Zend_Loader::loadClass('Zend_Filter_Geshi'); $zfg = new Zend_Filter_Geshi('php', '../site/lib/geshi/'); echo $zfg->filter(<<<ABC <?php Zend_Loader::loadClass('Zend_Filter_Geshi'); \$zfg = new Zend_Filter_Geshi('php', '../site/lib/geshi/'); ABC );

Autre endroit ou trouver ce code : http://www.z-f.fr/code/detail/17

Zend Framework (ZF) : un livre d’or, troisième étapes : Bases des fichiers

Créations d’un livre d’or en 6 étapes

  1. Définition
  2. Créations des tables sql et des répertoires
  3. Bases des fichiers
  4. Affichages et ajout de messages
  5. Modification et suppression des messages
  6. Conclusions

Bases des fichiers

Avant tout, il nous faut créer les différents fichier .htaccess

 RewriteEngine on #RewriteBase /serveur/mon_repertoire/ RewriteRule .* index.php php_flag magic_quotes_gpc off php_flag register_globals off

La ligne en commentaire, permet dans le cas d’une erreur de ce type : Fatal error: Uncaught exception ‘Zend_Controller_Dispatcher_Exception’ with message ‘Invalid controller specified (serveur)’ in de corriger le problème, pour un accès, par exemple, via : http://localhost/serveur/mon_repertoire/

LivreControllers.php

 <?php /** Zend_Controller_Action */ require_once 'Zend/Controller/Action.php'; class LivreController extends Zend_Controller_Action { 	public function indexAction() 	{ 		echo 'Index du livre d\'or'; 		return; 	} 	public function ajouterAction() 	{ 		$this->view->title .= ' .: Ajout d\'un message'; 		echo 'ajout d\'un message!'; 		return; 	} }

Le controlleur, c’est ce qui va diriger notre application

index.php

 <?php error_reporting(E_ALL|E_STRICT); date_default_timezone_set('Europe/Brussels'); set_include_path('.' . PATH_SEPARATOR . '../site/lib' . PATH_SEPARATOR . './app/models/'  . PATH_SEPARATOR . get_include_path()); include 'Zend/Loader.php'; Zend_Loader::loadClass('Zend_Controller_Front'); Zend_Loader::loadClass('Zend_Config_Ini'); Zend_Loader::loadClass('Zend_Registry'); Zend_Loader::loadClass('Zend_Db'); // load configuration $config = new Zend_Config_Ini('./app/config.ini', 'general'); $registry = Zend_Registry::getInstance(); $registry->set('config', $config); // setup database $db = Zend_Db::factory($config->db->adapter,  $config->db->config->toArray()); Zend_Db_Table::setDefaultAdapter($db); // Régler le dossier des contrôleurs par défaut : $frontController = Zend_Controller_Front::getInstance(); $frontController->throwExceptions(true); $frontController->setControllerDirectory('./app/controllers'); // run! $frontController->dispatch();

Livre.php

 <?php Zend_Loader::loadClass('Zend_Db_Table'); class Livre extends Zend_Db_Table {     protected $_name = 'livre';     protected $_primary = 'id'; 	public function insertObject($object) 	{ 		return parent::insert((array) $object); 	} 	public function updateObject($object, $where) 	{ 		return $this->update((array) $object, $where); 	} }

Le modèle du livre, c’est-à-dire les données -> ici la base des données.

Date.php

 <?php class MyWsp_View_Helper_Date { 	/** 	 * Retourne une date sous forme d'une chaîne, au format donné par le 	 * paramètre format, fournie par le paramètre timestamp ou la date et 	 * l'heure courantes si aucun timestamp n'est fourni. En d'autres termes, 	 * le paramètre timestamp est optionnel et vaut par défaut la valeur de la 	 * fonction time(). 	 * Plus d'info sur http://www.php.net/manual/fr/function.date.php 	 * 	 * @param string $format format de la date 	 * @param int $timestampdate à formaté 	 * 	 * @return string 	 */ 	public function date($format, $timestamp = null) 	{ 		if (!is_nan($timestamp)) 			$timestamp = time(); 		// see http://www.php.net/manual/fr/function.strftime.php 		$dates = array( 			'DDDD'	=> '%A', 			'DDD'	=> '%a', 			'DD'	=> '%d', 			'D'		=> '%e', 			'MMMM'	=> '%B', 			'MMM'	=> '%b', 			'MM'	=> '%m', 			'YYYY'	=> '%Y', 			'YY'	=> '%y', 			'HH'	=> '%H', 			'hh'	=> '%I', 			'mm'	=> '%M', 			'ss'	=> '%S', 		); 		return strftime(str_replace(array_keys($dates), array_values($dates), $format), $timestamp); 	} }

config.ini

 [general] db.adapter = PDO_MYSQL db.config.host = localhost db.config.username = root db.config.password = db.config.dbname = livredor

Contient la configuration pour accéder à la base de donnée du livre d’or.

Test

Rendez-vous à l’adresse de votre script :

  • Lire les messages : http://localhost/serveur/mon_repertoire/livre/
  • Ajouter un message : http://localhost/serveur/mon_repertoire/livre/ajouter/

Si tout est ok, passons à la suite!

Zend Framework (ZF) : un livre d’or, deuxième étapes : Créations des tables sql et répertoires

Créations d’un livre d’or en 6 étapes

  1. Définition
  2. Créations des tables sql et des répertoires
  3. Bases des fichiers
  4. Affichages et ajout de messages
  5. Modification et suppression des messages
  6. Conclusions

Créations des tables sql

Créer une nouvelle base de donnée dans votre serveur mysql. Ensuite exécuter la requête suivante :

CREATE TABLE `livre` (

 `id` int(10) unsigned NOT NULL auto_increment,  `date` int(10) unsigned NOT NULL,  `message` text character set utf8 collate utf8_unicode_ci NOT NULL,  `nom` varchar(60) character set utf8 collate utf8_unicode_ci NOT NULL,  PRIMARY KEY  (`id`),  KEY `inde` (`date`)

);

La structure de la table correspond donc a ceci :

Champ Type Défaut Extra
id int(10) auto_increment
date int(10)
message text
nom varchar(60)

Très simple et rien de compliquer jusque là, enfin normalement.

Structure du script

Les répertoires d’abords :

 /site     /lib         /Zend --> ici le zend framework /test     /app         /controllers         /models         /views             /scripts                 /livre

Et avec les fichiers :

 /app     /controllers         LivreControllers.php     /models        Livre.php     /views         /helpers         /scripts             header.phtml             footer.phtml             /livre                 livre.phtml                 ajouter.phtml     config.ini index.php .htaccess
Pourquoi une tel disposition?

En fait, ZF va chercher de manière automatique grâce, notamment, au ViewHelper où se trouve les différent fichiers et les charger automatiquement! Zf utilisé le système MVC, c’est-à-dire modèle-vue-contrôleur!

  • Contrôleur : Lien entre la vue et le modèle, réagit au requête de l’utilisateurs, etc
  • Vue : ce que voix l’utilisateur, souvent le système de templates, donc c’est la présentation des données!
  • Modèle : accès aux données, en gros accès à la base des données, au fichiers, etc

Cependant divers dossiers peuvent se trouver à d’autres emplacement, mais ici on fait dans le simple!

Pensez à utiliser mon script pour avoir plus facile …

Zend Framework (ZF) : un livre d’or, première étapes : définition

Créations d’un livre d’or en 6 étapes

  1. Définition
  2. Créations des tables sql et des répertoires
  3. Bases des fichiers
  4. Affichages et ajout de messages
  5. Modification et suppression des messages
  6. Conclusions

Définition des besoins

Pour faire un livre d’or très basique :

  • Ajout de message
  • Affichage de messages
  • Modération : modification et suppression des messages

Par après on peux ajouter différents éléments :

  • Smileys
  • Site-web et email des auteurs
  • Et des trucs plus fun : cache, css, …