Optimiser Wordpress (Conseils)

Voici une démonstration “powerpoint” pour vous donner quelques conseils d’optimisation de votre blog wordpress :

Eviter le Duplicate Content sur Wordpress 2.7

L’outils Wordpress est formidable, notamment cette version 2.7 qui véritablement changé l’administration.
Cette version 2.7 possède aussi quelques petits bugs de contenu dupliqué.

Eviter le Duplicate Content avec les Pages de commentaires

Wordpress 2.7 propose de séparer les commentaires sur plusieurs pages, agréable pour la lecture d’une page avec la création d’une page :

http://www.alexandreval.info/cv/blablablabla/comment-page-X

Cette page faisant référence à

http://www.alexandreval.info/cv/blablablabla/

Il se produit alors un duplicate content sur les pages de commentaires. C’est pas très bon pour le référencement, Google n’aime pas cela, alors mieux vaut être gentil avec GG et lui fournir une page “propre”. Pour éviter ce contenu dupliqué, il suffit de rajouter cette petite fonction dans votre page function.php (située dans votre dossier wp-content/theme/NOM_DU_THEME/ :

function noindexoncommentinwp(){
global $wp_query;
if (version_compare( (float) get_bloginfo(’version’), 2.7, ‘>=’) ){
if ($wp_query->is_singular && get_option(’page_comments’)){
if (isset($wp_query->query['cpage'])
&& absint($wp_query->query['cpage']) >= 1 ){

echo ‘<meta name=”robots” content=”noindex” />’.PHP_EOL;
}
}
}
}

add_action(’wp_head’,'noindexoncommentinwp’);

Cette fonction rajoutera une balise meta no follow pour indiquer aux moteurs de ne pas indexer cette page ;)

Eviter le Duplicate Content avec les Multi Page

Comme pour les commentaires, les pages multiples pour un article créent du contenu dupliqué, on peut alors créer une fonction qui va ajouter la même balise que dans la fonction au dessus.

function noindexinwp(){
global $wp_query;
if(is_single && $wp_query->query[page]) echo “\t”.’<meta name=”robots” content=”noindex,follow” />’.”\n”;
}
add_action(’wp_head’, ‘noindexinwp’, 1);

Avec cela, vous êtes parés pour recevoir les félicitations de notre ami Google ;)

Article rédigé d’après la trouvaille de NWE, et de l’astuce découverte par Julien.

Comment déboguer du code PHP : La solution !


Comment déboguer du code PHP avec FirePHP, extension de FireBug, plugin indispensable aux développeurs.

Le navigateur le plus rapide : Safari

Safari est le navigateur le plus rapide dans linterprétation de javascript. Vincent Hermann de PCINpact s’est amusé à passer tous les navigateurs sous SunSpider, qui permet de tester la vitesse d’interprétation du Javascript. Résultats cinglants pour IE…

A noter que le nouveau navigateur de Google, Chrome, monté sur Webkit s’en tire plutôt pas mal !

Ne plus être spammé sur son site/blog

Comment ne plus recevoir de spam sur son site/blog ? C’est la question que tout le mon s’est posé une fois.
Je ne vais pas vous parler de scripts à mettre en place, de Captcha ou d’inscriptions avant de commenter un message.

Ma technique est la suivante, et elle fonctionne à 99% des robots spammers.
Il suffit de mettre en place un champs texte placé dans le formulaire qui sera caché par un style css :

  1. <input type="text" name="pseudo" value="" style="visibility:hidden" />

Il faudra vérifier à l’envoi du formulaire si ce champs a été renseigné. Si c’est le cas, alors c’est un robot qui l’a rempli. Un robot de spam remplit automatiquement tout les champs du formulaire qu’il trouve dans le code source de la page. Il pourra donc voir ce champs caché et tomber dans le piège.

Il faut donc vérifier que le champs a été renseigné :

  1. $pseudo = trim($_POST[‘pseudo’]);
  2. if(!empty($pseudo) || $pseudo!=){
  3. die(mysql_error()); //Bye Bye le robot.
  4. }

Je l’ai testé sur Tuxboard.com, je recevais pas moins de 500/600 spams par jours, et maintenant, j’en reçois 1 voire 2 maximum par jour !

Vous obtiendrez en plus de cette suppressions nauséabondes de spams, un gain de performance car il n’est pas s’en rappelez que vous ne subirez pas les utilisations de requêtages des robots et tout cela sans ajout de scripts et autres captcha, souvent illisibles.
Évidemment, cette technique n’a aucun moyen de lutter contre les utilisateurs/spammeurs qui polluent les blogs.

Tout savoir sur un site web avec QuarkBase

Le site propose QuarkBase propose plusieurs informations utiles pour un site internet :
- Description du site avec les balises meta, les sites qui sont similaires au vôtre.
- Popularité dans les sites communautaires (Digg, Twitter, Technorati…), et les backlinks.
- Traffic de votre site grâce aux stats de Alexa.com.
- Et les informations concernant le propriétaire et son hébergement (IP, hébergeur…)

quarkbase

Il y a aussi d’autres sites similaires à quarkbase :
- urlmetrix
- aboutus
- alexa

quarkbase

Développement Game Credits sur Game-Credits.org

Je viens de terminer un site sur les acteurs des jeux vidéo : Game Credits, réalisé pour la société Connection Events, qui organise la Game Connection dans le monde entier ainsi que la Paris GDC, conférence sur les jeux vidéo entre professionnel.

Game Credits est donc pour les PRO du jeux vidéo, une sorte de IMDB des jeux avec les personnes ayant travaillé sur les jeux vidéos, les sociétés éditrices, productrices ou développeurs.
Le site a été développé en PHP/MySQL avec le CMS Smarty. Pourquoi ? Tout simplement parce qu’un développeur de Connection Events avait déjà réalisé la structure du site avec. J’ai repris l’existant en adaptant la structure pour respecter le cahier des charges.

Game Credits propose les crédits d’un jeu :

Les informations d’une société

Les informations limitées d’un utilisateur (employé) :

Interdire le Hotlinking d’image

Qu’est-ce que le hotlinking d’image ?
C’est l’utilisation de ressources (images) provenant d’un site (A), que l’on utilise sur un autre (B) en gardant le lien d’origine (Lien ressource A).
Cela pose problème puisque notre webmaster (A) doit supporter les accès au fichier du site (B).
Pour interdire le Hotlinking (d’image), voici une petite astuce. On utilisera le .htaccess qui sera interprété par Apache.

Je reprendrai l’exemple de mon blog (Tuxboard.com) souvent visité et fréquemment “pompé”.
Il faudra au préalable activer le module de rewrite d’apache.
Dans le fichier .htaccess :

  1. RewriteEngine On
  2. On autorise les sites qui peuvent utiliser la ressource :
  3. RewriteCond %{HTTP_REFERER} !^http://(www\.)?tuxboard.com(/)?.*$ [NC]
  4. RewriteCond %{HTTP_REFERER} !^http://(www\.)?google.com/reader(/)?.*$ [NC]
  5. Et aussi les moteurs pour le référencement :
  6. RewriteCond %{HTTP_USER_AGENT} !^Googlebot [NC]
  7. RewriteCond %{HTTP_USER_AGENT} !^Googlebot-Image [NC]
  8. RewriteCond %{HTTP_USER_AGENT} !^Googlebot-Mobile [NC]
  9. RewriteCond %{HTTP_USER_AGENT} !^Msnbot [NC]
  10. RewriteCond %{HTTP_USER_AGENT} !^Slurp [NC]
  11. RewriteCond %{HTTP_USER_AGENT} !^Mediapartners-Google [NC]
  12. #Lien pour autoriser Google image d’indexer et d’utiliser l’image
  13. RewriteCond %{HTTP_REFERER} !^http://.*google\.(com¦(co\.)?[a-z]{2})/

Ensuite il existe plusieurs façon de montrer à l’utilisateur du site (B) que l’image provient du site (A) :
On affiche une erreur :

  1. RewriteRule \.(gif|jpe?g|png|bmp)$ - [F]

On affiche une image, précisant les types d’images que l’on souhaite protéger.

  1. RewriteRule \.(gif|jpe?g|png|bmp)$ /images/no-hotlink.jpg [L,NC]

Ce qui affichera par exemple pour cette image du site Tuxboard :
http://images.tuxboard.com/d/8257-1/iphone+3G+photos.jpg

Pour tester que votre code fonctionne, rendez vous sur ce site pour coller l’URL de votre image.

Pour les blogs avec les RSS, vous pouvez autoriser les RSS readers que vous pensez être utile (vu chez Korben) :

  1. RewriteCond %{HTTP_REFERER} !^http://(www\.)?netvibes.com(/)?.*$ [NC]
  2. RewriteCond %{HTTP_REFERER} !^http://(www\.)?bloglines.com(/)?.*$ [NC]
  3.  

Fonction PHP retournant une Liste déroulante / Multi-Select

Suite à un billet d’un collègue développeur (Jarodxxx), et d’un commentaire souhaitant obtenir un return, je vous propose quelques fonctions très utiles que j’utilise.

1 - Fonction qui retourne une liste déroulante (SELECT, ComboBox) :

  1. /*fonction qui fabrique une combobox
  2. parametres :
  3. $tabs => $tableau qui contient les données a mettre dans la combo
  4. $value => champ utiliser comme value
  5. $text => champ a utiliser comme text
  6. $comboname => nom a donner a la combo
  7. $inserblank => boolean qui dit si on doit inserer une ligne blanche au debut de la combo
  8. $selectedValue => valeur a selectionner dans la combo
  9. $onChangeEvent => fonction javascript a appeler sur l’event ‘onChange’
  10. $disabled => desactiver ou non la liste*/
  11.  
  12. function makeComboBox($tabs, $value, $text, $comboname, $insertblank=false, $selectedValue=false, $onChangeEvent=, $disabled=false)
  13. {
  14.                   /*par defaut, combo "vide" */
  15.                     $return = ‘<select name="’.$comboname.‘" id="’.$comboname.‘" disabled="disabled"><option value="">Empty list</option></select>’;
  16.                     if (count($tabs[0]) > 0)
  17.                     {
  18.                               $return = ‘<select name="’.$comboname.‘" id="’.$comboname.‘"’;
  19.                               if ($onChangeEvent != )
  20.                                         $return .= ‘ onChange="’.$onChangeEvent.‘"’;
  21.                               if ($disabled)
  22.                                         $return .= ‘ disabled="disabled"’;
  23.                               $return .= ‘>’;
  24.  
  25.                               if ($insertblank)
  26.                                         $return .= ‘<option value=""></option>’;
  27.  
  28.                               foreach($tabs as $tab){
  29.                               //for ($i=0; $i<count($tab); $i++){
  30.  
  31.                                         $return .= ‘<option value="’.$tab[$value].‘"’;
  32.                                         if ($selectedValue!=false)
  33.                                                   if ($tab[$value] == $selectedValue)
  34.                                                             $return .= ‘ selected="selected"’;
  35.                                         $return .= ‘>’.$tab[$text].‘</option>’."\n";
  36.                               }
  37.                               $return .= ‘</select>’;
  38.                     }
  39.                     return $return;
  40. }
  41.  

2 - Fonction qui retourne un Multi Select : Liste déroulante avec plusieurs choix possibles:

  1. /*Gestion des combos a selection multiples
  2. parametres :
  3. $tab => $tableau qui contient les données a mettre dans la combo
  4. $value => champ utiliser comme value
  5. $text => champ a utiliser comme text
  6. $comboname => nom a donner a la combo
  7. $inserblank => boolean qui dit si on doit inserer une ligne blanche au debut de la combo
  8. $selectedValue => valeur a selectionner dans la combo
  9. $onChangeEvent => fonction javascript a appeler sur l’event ‘onChange’
  10. $disabled => desactiver ou non la liste
  11. $size => Nombre d’élément de la liste que l’on affiche
  12. */
  13. function makeMultipleComboBox($tab, $value, $text, $comboname, $insertblank=false, $selectedValue, $onChangeEvent=, $disabled=false, $size=5)
  14. {
  15. /*on recupere une combo normale, sans rien selectionner*/
  16. $return = $this->makeComboBox($tab, $value, $text, $comboname, $insertblank, -1, $onChangeEvent, $disabled);
  17. /*On change le type de combo*/
  18. $return = str_replace(‘<select ‘, ‘<select multiple size="’.$size.‘" ‘, $return);
  19. /*on parse le code html pour rajouter les selections la ou il faut*/
  20. if (!empty($selectedValue))
  21. {
  22. //print_r($selectedValue);exit;
  23. //$tSelectedValue = split(’,', $selectedValue);
  24. foreach ($selectedValue as $cur)
  25. {
  26. $return = str_replace(‘<option value="’.$cur.‘">’, ‘<option value="’.$cur.‘" selected="selected">’, $return);
  27. }
  28. }
  29. return $return;
  30. }
  31.  

2 fonctions très utiles donc qui génèrent le code HTML.

Alterner le contenu de 2 DIV (Javascript / CSS)

Voici un code pour alterner le contenu de 2 DIV et avec un seul lien.

On va créer tout d’abord 2 div contenant 2 textes à alterner avec un CSS element.style.display différent.

<div id=”mod_1″ style=”display: block;”> BONJOUR </div>

<div id=”mod_2″ style=”display: none;”> AU REVOIR </div>

Explication : element.style.display ne retourne une valeur que si l’élément a un attribut HTML style avec propriété CSS display renseignée, donc dans notre cas, la DIV avec l’id mod_1 sera affichée au chargement de la page tandis que mod_2 sera cachée.
Il nous faut un lien pour pouvoir alterner entre les 2 div.

<a onclick=”alterner(’mod_1′,’mod_2′);” title=”Alterner les 2 div”>Alterner</a>

Il nous manque plus que le Javascript :

<script type=”text/javascript”>
function alterner(obj1, obj2){
var obj1 = document.getElementById(obj1);
var obj2 = document.getElementById(obj2);
obj1.style.display = (obj1.style.display == “block”) ? “none” : “block”;
obj2.style.display = (obj2.style.display == “block”) ? “none” : “block”;
}
</script>

Que va faire le script ? Si la DIV mod_1 (obj1 la fonction javascript) est à display:block (affichée) alors on définit la DIV mod_2 à display:none (cachée) et inversement.

Voici un exemple en cliquant sur le lien “Alterner les DIV” :
Alterner les DIV

BONJOUR

(PHP) Mettre des majuscules aux premières lettres

Je commence à vous montrer quelques scripts et astuces pour améliorer vos codes (PHP).
Une petite astuce toute simple pour mettre des majuscules à tous vos mots d’une chaîne de caractères. La fonction ucwords(); de php le permet , exemple :

$chaine = ‘alexandre val developpeur web’;
echo ucwords($chaine);

Ce qui affichera :

Alexandre Val Developpeur Web

Attention : la fonction ne comprend pas les ‘-’, ‘_’ ‘(’ devant les lettres. ce qui fait qu’une phrase comme celle-ci :

echo ucwords(’alexandre val (developpeur web)’);

affichera :

Alexandre Val (developpeur Web)

N’oubliez pas les fonction pour tout réduire en minuscule : strtolower(); et en majuscule : strtoupper();
strtolower(), que l’on peut combiner avec ucwords() pour formatter le texte, exemple :

$chaine = ALEXANDRE VAL DEVELOPPEUR WEB’;
echo ucwords(strtolower($chaine));

Affichera :

Alexandre Val Developpeur Web

Développements récents

- Réalisation d’un site sur les acteurs des jeux vidéos façon IMDB. : Games Credits

- Refonte graphique de mon site CV Freelance. Voir la précédente version.

- Développement d’une page de démarrage personnalisable. Cliquez pour voir l’explication

- Administrateur du Site/Blog Tuxboard.com.
Plus de 30.000 visiteurs quotidien. Consultez les statistiques en détails de mon blog.
Design CSS, développement PHP/MySQL, retouche Photoshop et administration Linux (Debian).
Disponible à cette adresse.

- Développement du site Wanimo.com.
Design CSS, développement PHP(Objet)/MySQL, retouche Photoshop.
Disponible à cette adresse.

- Création du site Cronos
Découpe Photoshop, intégration graphique, design CSS, développement PHP.

- Développement de modules pour un forum de poker : Lyonholdem.com
Création de module greffés au forum de discussion et au backoffice.
Disponible à cette adresse.

- Développement d’une boutique en ligne simplifiée (Paiement par Paypal/CB).
Possibilité d’upgrader en boutique en ligne avec paiement en ligne CB.
Disponible à cette adresse.

Auteur du Blog www.Tuxboard.com


Cliquez pour agrandir
 

Tuxboard.com

  Blog
Blog créé début 2007, consacré aux Clips vidéo musicaux, images insolites, Photos, Publicité, playlists musicales.
Tuxboard.com compte à ce jour (16 octobre 2007) plus de 25.000 visites quotidiennes.
Consultez les statistiques du blog Tuxboard.com
Développement d’outils pour le site, de plugins pour Dotclear.

Projets Chez Elao

 

Wanimo.com

  Site grand public.Développement d’un site marchand (ventes de nourriture, accessoires animaux).
Mise à jour de la base de données du site : Lotus en MySQL/PHP.
Développement outils mon compte, modules de backoffice.
Design CSS, Retouche Photoshop.
Langage utilisé : PHP/MySQL, HTML/CSS (W3C)
 

Projets Chez Jet Multimedia

Création d’un système de cache en PHP orienté objet pour sites pour téléphone mobile.

Projets Chez Kouro Sivo

 

TetraPak.fr

  Site grand public. Reprise de l’existant : créations / modifications des pages et ajout de communiqués de Presse. Retouche d’images.
Langage utilisé : PHP/MySQL, HTML/CSS (W3C)
Lancements d’emailings mensuels.
 

 

Orange Alchemy

  Développement du site Orange Alchemy en ASP / SQL Server.
Spécificités : Gestion des points, classement, boutique online avec prise de commande.
Lancements d’emailings mensuels.
 

 

Alcatel Business Partner

  Développement du site en PHP 5 / MySQL.
Site réalisé en 5 langues :
FR / ANG / ALL / ITA / ESP.
Spécificités : Gestion compte points, challenges commerciaux, boutique cadeaux.
Lancements d’emailings.
 


Cliquez pour agrandir
 

The Rewards Catalog

  Développement du site en PHP / MySQL.
Boutique en ligne avec possibilités de commandes.
Spécificités : Gestion de compte points, multilangues ( FR / ANG / ALL / ITA / ESP), Back-Office.
 


Cliquez pour agrandir
 

Volvo Finance Race 2005

  Développement du site en ASP / SQL Server.
Spécificités : Gestion de points, classement, boutique online avec prise de commande.
Lancements d’emailings mensuels.
 

 

Business Object - Pôle Position

  Développement du site en ASP / SQL Server.
Spécificités : Gestion des points, classement des ventes, intégration d’un jeux à Instants Gagnants.
Lancements d’emailings mensuels.
 

 

Renault Trucks Excellence Club

  Reprise de l’existant : créations / modifications de pages.
Retouche d’image.
Langages utilisés :ASP, HTML/CSS.
Mise en place d’un diaporama de photos.
 

 

Arval - Banque Populaire

  Reprise de l’existant : créations / modifications de pages.
Spécificités :Gestion des points, classement.
 

 

The Phone House - Carat

  Reprise de l’existant : créations / modifications de pages.
Lancement de challenges commerciaux
Spécificités :Gestio

Divers Fonds d’écran / Wallpaper

Les fonds d’écran ont tous été créé sous Photoshop en 2004.

Télécharger ce Wallpaper

Télécharger ce Wallpaper

Télécharger ce Wallpaper

Télécharger ce Wallpaper

Télécharger ce Wallpaper

Télécharger ce Wallpaper