La RC de Firefox bientot dans les depots d’hardy

Allez hop …

La RC sera dans les dépots bientot ^^ (source planet.ubuntu-fr.org), en attendant que les dev de plugins porte leurs sympatique appli pour la version 3, voici une extension qui pourrait être très utile dans les prochain mois : http://www.oxymoronical.com/

C’est une extension pour forcer la compatibilité des anciennes extension avec Firefox 3 …

Cela dit, il est peut-être préférable de d’attendre les mise à jour officiel 😉 Car certaine fonction ont été supprimé, ou bien certaine extension qui utilisait des « hacks » ont été bloqué, … Donc voila ^^

Bon sinon, pour faire tourner firebug (la meilleur extension pour les dev web et les hackers ?? ^^) sur firefox3 (c’est la version beta qui marche très mal mais qui rajoute quelque petit truc sympa).

kické de l’index …

Bijour à tous …

Après 3 ans à squatter la première page pour la requête programmation php sur google … aujourd’hui plus rien, et la plupart des autres requête pour lesquel j’apparaissait premier (xajax, socket c++, …) nada … dur loi du référencement ??

Deux théorie possible :

  1. Changement de calcul pour google
  2. Dé-référencement sauvage

Pour la deuxième théorie …

La plupart du temps, lorsque quelqu’un demande un « dé-référencement » à google (pour faire crade …), la commande : site:php-engineering.info ne renvoit que dalle, l’ennui, c’est que ici j’ai encore tous mes liens … donc je retombe sur la 1ère théorie … je vais de nouveau devoir chercher de nouvelle technique pour exploiter google 😉

Si vous avez des idées xd …

Edit: C’est de nouveau bon … ^^, ce n’était que temporaire … mais sur le coup … 😉

Améliorer le référencement grace aux php

Bon … mon standing oblige xD ce soir : référencement et PHP (une fois n’est pas coutume).

Alors bon … vous aurez surement remarqué que bon l’url rewriting c’est bien … mais souvent des sites utilisant des urls bizzare sont mieux référencés … allez savoir pourquoi xD.

En vrai, ils font souvent appel au PATH_INFO … hein?!

en vrai c’est ce qui se trouve dérrière le nom de domaine :

http://loser-php/index.php/mon/site/rox/autant/que/mon/seo

Le PATH_INFO contient « /index.php/mon/site/rox/autant/que/mon/seo« , ça sert à quoi me direz-vous … hé ben vous remarquez une première chose : pas de ? et de = caractères que certain moteur de recherche n’affectionne que moyennement, ensuite le séparateur est un / et pourquoi c’est mieux qu’autre chose (-,.) ???

Tout simplement car un moteur de recherche est obligé de prendre en compte les / alors que la compréhension des -,. et autre signe peut être différentes suivant les moteurs de recherche. (Je viens de vous apprendre qu’il y a d’autre moteur de recherche ??? Non :p)

Sachant que le nom du dossier contenant le fichier sur lequel on fait référence à a peu près le même poids (parfois plus ^^), que le fichier en question, il peut être donc très avantageux dans certain cas d’avoir dev son site en utilisant le path_info. D’autant plus qu’une url en path_info peut être plus facile à retenir qu’une url rewrité …. (http://php-loser/index-9-1-7-mon_super-titre, de-la-mort-ki-tu-pas-sa-race.html ou bien http://php-loser/index.php/mon /super/titre/qui/defonce/la/concurrence/). Et oui … on peut parfois confondre le _ avec -, et … donc en path_info, on sait qu’il y a toujours des / donc ^^

Donc voila un simple exemple :

$path_info=$_SERVER['PATH_INFO']; //on récupère le path_info
$path_info_explode=explode("/",$path_info);

//  et ensuite on recupère les élements dans le tableau ...
//  si l'on reprend l'url :
//  http://php-loser/index.php/mon/super/titre /qui/defonce/la/concurrence/

echo $path_info_explode[1]; //ecrit mon, et oui le 0 faisant référence à l'index.php 🙂
echo $path_info_explode[7]; //ecrit concurrence.

bon … c’est sur, si vous utilisez une base de données, il faudra à chiffre tôt ou tard … le plus tôt étant le mieux, il suffirait de faire comme ceci :

http://php-loser/index.php/1/mon/titre

et de récupérer le chiffre par la méthode vu plus haut.

Bon c’était un rapide exemple … j’imagine qu’il n’en faut pas plus 😉

Netbeans6 et auto-complétion QT4

Bonjour …

La méthode de la version 5 ne marchant plus … Si l’on include direct QApplication ou d’autre ça ne marche pas si l’on fait référence seulement à /usr/include/qt4/ (méthode qui fonctionnait sur l’ancienne version …).

Donc je fait un rapide billet histoire de me souvenir de la manip’ (comme je programme pas souvent en C++)…

  1. Clic droit sur le nom du projet.
  2. Properties (propriétés) puis C++ compiler et choisir le dossier d’include …

et voilà, … ça tourne impec’ :p … il en faut peu pour être heureux 😉

(Bon l’alternative aurait été de faire un include de <QTGui/QApplication> … mais bon faudrait modifier pas mal de projet pour le prendre en compte alors ;)).

Les recherches des personnes sur le net suivant leurs cultures …

Bonjour …

en lisant s2m ajourd’hui, j’ai trouvé une superbe url :

http://www.google.com/intl/en/press/intl-zeitgeist.html

c’est un compte rendu des recherches (top15) faites par pays …

Quelque truc marrant :

Plus de 50% des recherches par les afghans porte sur l’Afghanistan … seul le gouvernement à des PC ou des hackers qui cherchent des failles??

Environ 30% des recherches faites par les Canadiens porte sur les voyages et les cultures étrangères …

Chine : carrefour en 5ème position!!!

Italie : big brothers en tête … les italiens viennent de comprendre ce qu’est internet :p

Norvège : …. inquiété par les aliens : 9ème position xD

Arabie Saoudite : à la recherche d’anonimité (8e) et Nicole Kidman (2e) … pourquoi ??

Suède : … Hitler 13e ??? Je savais qu’ils étaient raciste … mais à ce point :p. A noté que les stars de Walt Disney sont recherché : Pinochio(15), Mickey(5)

Ukraine : Pays du P2P ->Torrent(1) … faut dire qu’avec le réseau internet qu’ils ont 😉

UK : Chihuahua (1) et thé(6) …ils changeront jamais :p

Hop … ça ne sert à rien de savoir tous ça, mais ça donne un peu une idée de la vie des geeks des autres pays 😉

Netbeans 6.1 PHP et Cpp

Héhé … j’ai trouvé suite à l’un de mes précédent post comment installer proprement le plugin C++ sur un Early Access … c’est un tous petit peu plus propre …

Il suffit de rajouter cette url de mise à jour et de choisir le plugins C++

Et on peut aussi rajouter les autres histoire d’avoir un truc complet :

Lien 1 Lien2 Lien3

Je trouve dommage d’avoir séparé la version PHP du reste de l’IDE car en plus, l’ensemble des plugins proposés dans la Early Acess ne sont pas dispo, même dans la version Full … d’où l’expression alsacienne être « Full » (ne pas confondre pas avec le mot anglais ^^), à noter que l’alsacien ne s’écrivant pas … je sais pas comment ça s’écrit :d …

JavaFX … quelque liens utile

Je ne vais pas dire que je suis fan de java … mais bon javafx a du potentiel … d’autant plus que c’est plutôt bien géré par linux … déjà mieux que flex ou encore silverlight ^^.

Alors bon … quelque liens rapide : (histoire que je les ai sous la main le jour où j’en ai besoin ^^)

Le Wiki

La page de résumé

L’adresse de la doc

Le plugin de dev de javafx pour netbeans

La page de l’API

… A partir de la … on peut déjà faire pas mal. (rien qu’avec la doc de l’api…)

Ajax et infobulle

Ben voilà … nouvelle article sur l’ajax, une petite astuce pour notifier le visiteur d’événement survenue avec ajax. La plupart du temps en ajax on privilégie une zone sur l’écran, au centre, tout en haut, tout en bas.

J’expérimente depuis quelque temps déjà, une autre zone, qui est elle aussi assez souvent bien vue par l’utilisateur … a coté du pointeur de la souris :

Le pointeur de la souris est manquant … mais faut l’imaginer quoi :p

Donc voila le code :

Le CSS dont on a besoin :

#infobulle {
    background-color:white;
    border:1px solid #CCCCCC;
    font-family:Verdana,Arial;
    font-size:0.7em;
    padding:10px;
    position:fixed;
    visibility:hidden;
}

Le code Javascript :

var timeOUTaffBulle=null;
var bubble = document.getElementById("infobulle");
var cursor_padding = 5;
var nav = navigator.appName;
var ie = document.all;
var ns = document.layers;
if(!ie)
 document.captureEvents(Event.MOUSEMOVE);

document.onmousemove = get_mouse;

function get_mouse(e){
 if(ie){
 x = event.x;
 y = event.y;
 window.status = x;
 }else{
 x = e.pageX;
 y = e.pageY;
 }

 bubble = document.getElementById("infobulle");
 bubble.style.left = x + cursor_padding+'px';
 bubble.style.top = y - document.documentElement.scrollTop + cursor_padding+'px';
}

document.onmousemove = get_mouse;

// affiche la bubble
function see_bubble(text){
 bubble.style.visibility = "visible";
 bubble.style.display = "block";
 if(timeOUTaffBulle!=null)
 bubble.innerHTML+="
"+text;
 else
 bubble.innerHTML = text;
}

function affBulle(text)
{
 see_bubble(text)
 timeOUTaffBulle=setTimeout("kill_bubble()",1800)
}

function kill_bubble(){
 bubble.style.visibility = "hidden";
 bubble.style.display = "none";
 if(timeOUTaffBulle!=null)
 {
 clearTimeout(timeOUTaffBulle);
 timeOUTaffBulle=null;
 }
}
/*FIN INFOBULLE*/

Donc voila … il suffit juste de mettre une div avec comme id « infobulle » et d’appeler la fonction : affBulle(‘Salut à vous …’);
Pour afficher une superbe infobulle à côté de votre souris.

Gérer les accents en Ajax

Un rapide article sur la gestion des accents en Ajax, avec scriptaculous (bien entendu).

Rapide rappel :

Faire une requete en GET avec scriptaculous :

new Ajax.Request('url',
{
    asynchronous:true,
    onSuccess: function(e) {
        //le traitement
    }
});

Les requetes en POST avec scriptaculous :

new Ajax.Request('url',
{
    method:'post',
    postBody:'param1='+escape(document.getElementById('val1').value)+
    '&param2='+escape(document.getElementById('val2').value),
    asynchronous:true,
    onSuccess: function(e) {
        //traitement
    }
});

Et donc pour rajouter le support des accents, il faut rajouter l’option :

encoding: ‘iso-8859-1’

Faire une requete en GET avec les accents :

new Ajax.Request('url',
{
    asynchronous:true,
    encoding: 'iso-8859-1',
    onSuccess: function(e) {
        //le traitement
    }
});

Les requetes en POST avec les accents :

new Ajax.Request('url',
{
    method:'post',
    postBody:'param1='+escape(document.getElementById('val1').value)+
    '&param2='+escape(document.getElementById('val2').value)+
    asynchronous:true,
    encoding: 'iso-8859-1',
    onSuccess: function(e) {
        //traitement
    }
});

Et voilà, plus aucun problème avec les accents et autre caractères spéciaux. (En français bien sur).

Réduire la consommation de bande passante (Apache mod_deflate)

Rapide mémo sur la configuration du mod_deflate de apache qui permet de réduite pas mal la consommation de bande passante en compressant les données à la volée avec gzip avant de l’envoyer au client :

Tous d’abord, on charge le module dans la config :

Debian : a2enmod deflate

Ubuntu : sudo a2enmod deflate

Ensuite :

on ouvre le fichier apache2.conf ou httpd.conf, et l’on met l’une de ces lignes :

Si l’on veut seulement compresser les fichiers html, xml, et texte plein …

AddOutputFilterByType DEFLATE text/html text/plain text/xml

ou si l’on veut tous compresser par défaut

SetOutputFilter DEFLATE
SetEnvIfNoCase Request_URI \.(?:gif|jpe?g|png)$ \
no-gzip dont-vary
SetEnvIfNoCase Request_URI \
\.(?:exe|t?gz|zip|bz2|sit|rar)$ \
no-gzip dont-vary
SetEnvIfNoCase Request_URI \.pdf$ no-gzip dont-vary

ou pour compresser suivant le navigateur :

BrowserMatch ^Mozilla/4 gzip-only-text/html
BrowserMatch ^Mozilla/4\.0[678] no-gzip
BrowserMatch \bMSIE !no-gzip !gzip-only-text/html

Pour avoir des logs :

DeflateFilterNote Input input_info
DeflateFilterNote Output output_info
DeflateFilterNote Ratio ratio_info
LogFormat ‘ »%r » %{output_info}n/%{input_info}n (%{ratio_info}n%%)’ deflate
CustomLog /var/log/apache2/deflate_log deflate