Quelques plugins jQuery utiles

Voici trois plugin jQuery que j'utilise relativement souvent :

- Time ago



Permet de modifier un timestamp en : "Il y a 4 minutes" ou "Il y a 8 jours", "Il y a un mois" comme ce qu'on peut voir dans les timeline de Twitter ou Facebook.

- jQuery Validation



Permet la validation des champs d'un formulaire avant d'être envoyé.

- jCrop



Permet de retailler une image sur un site internet. J'avais fait ce genre de code en javascript + php (sur le site de Live9 pour l'envoi des pochettes) avant de trouver ce plugin jQuery.

N'hésitez pas a partager vous aussi les différents plugins que vous utilisez régulièrement.


Ranger ses onglets, gagner de la mémoire

J'ai un gros problème de gestion d'onglet, généralement j'ai entre 50 à 80 onglets sur Firefox. Je ne range jamais ces onglets (certains vont dire mais il y a des marques pages...) C'est vrai mais j'utilise pas les marques pages comme ça. Les marques pages c'est pour des sites que je visite rarement. Par contre les blogs, sites que je visite souvent je ne ferme pas les onglets.

J'utilise donc un plugin firefox TooManyTabs qui trie par "groupe" les onglets ouverts.

J'ai donc créer des groupes : travail, a lire, blog, réseaux sociaux, etc...
Il suffit de selectionner sur le groupe ou ont veut ranger l'onglet puis de cliquer au niveau du favicon de l'onglet pour ranger l'onglet dans le groupe.
On peut ensuite "resortir" l'onglet du groupe pour le voir.

A savoir une fois l'onglet "ranger" dans un groupe le plugin supprime l'onglet de la mémoire de Firefox (donc on gagne en performance).


Envoi de mail avec CodeIgniter plain/text [edit ET text/html]

Nous allons aujourd'hui envoyer un mail grâce à CodeIgniter.

Pour cela il faut créer un fichier email.php dans le répertoire application/config/
Dans ce fichier plusieurs méthodes pour envoyer un mail soit via "mail", "sendmail" ou via "smtp".
Nous allons utiliser un compte mail donc le SMTP.

<?php  if ( ! defined('BASEPATH')) exit('No direct script access allowed');

$config['protocol'] = 'smtp';
$config['smtp_host'] = 'smtp.domaine.com';
$config['smtp_port'] = 25;
$config['smtp_user'] = 'mail@domaine.com';
$config['smtp_pass'] = 'motdepasseducomptemail';

Créer ensuite un contrôleur par exemple controllers/home.php
Dans votre home vous allez créer la méthode "send" qui permet l'envoi du mail.

<?php
class Home extends Controller {

	function Home()
	{
            parent::Controller();
	}

	function index()
	{
            // On charge la vue index
            $this->load->view('index');
	}

	function mail()
	{
            $this->load->library('email');
            $this->email->set_newline("\r\n");
            $this->email->from('email@domaine.com', 'Prénom NOM');
            $this->email->to('destinataire@domaine.com');
            $this->email->subject('Titre du mail');
            $this->email->message('Contenu du mail.');

            if($this->email->send()) {
                echo 'E-mail envoyé !';
            } else {
                echo 'Oup\'s ! Il y a eu un soucis lors de l\'envoi !';
            }
	}
}

Ce code fonctionne parfaitement en "plain/text".

Pour envoyer un mail au format html modifier votre fichier config/email.php :

<?php  if ( ! defined('BASEPATH')) exit('No direct script access allowed');

// Ajout du format html (mail en html)
$config['mailtype'] = 'html';
// Ajout de l'encodage du mail
$config['charset']  = 'iso-8859-1';

$config['protocol'] = 'smtp';
$config['smtp_host'] = 'smtp.domaine.com';
$config['smtp_port'] = 25;
$config['smtp_user'] = 'mail@domaine.com';
$config['smtp_pass'] = 'motdepasseducomptemail';

Et dans votre contrôleur modifier le contenu du message par un contenu avec des balises html comme ceci par exemple :

$this->email->message('<p>Contenu du mail <b>en gras</b>.</p>');

Impossible pour nous d'envoyer un mail au format HTML avec CodeIgniter pour l'instant !
J'ai laissé un message sur le forum de Code Igniter pour voir si ça vient pas du framework directement ou moi qui ai mal compris un truc ;-)

Edit : Il fallait ajouter le type d'encodage du mail pour pouvoir envoyer au format HTML ;)


Nouveautés 2010 !

Cette année quelques choses changeront :
Le support d'IE6 ne sera plus pris en compte quel que soit le projet. Internet Explorer 7 et 8 étant en place depuis déjà pas mal de temps.
Dates de sortie :
- Le 18 Octobre 2006 pour Internet Explorer 7 (soit 3ans et 3mois)
- Le 11 Juin 2009 pour Internet Explorer 8 (soit 6mois)
Il est donc temps je pense d'abandonner Internet Explorer 6 qui a eu 8ans en Octobre dernier !

Sur le blog faire de plus en plus d'articles techniques sur des frameworks tel que : jQuery et CodeIgniter et des tips sur CSS3...

Et d'autres points sur lesquels nous travaillons : le développement d'applications (pc, mac, mobile), d'interfaces et de site web, l'hébergement, l'infogérance, la téléphonie et les cours également (les cours de développement d'application Twitter, Facebook, jQuery etc...).
Dans les cartons pour le début de l'année la sortie d'un Scheduler Radio !

N'hésitez pas a prendre contact avec nous si vous avez des questions ou besoin d'informations.
Meilleurs Vœux pour l'année 2010 !


jQuery + CodeIgniter + Référencement

Sur un site j'utilise CodeIgniter et un plug in jQuery pour la navigation (sans recharger tout le contenu).

La navigation comme ça c'est bien mais ça ne fonctionne pas partout et pour le référencement c'est pas terrible.

Donc je vais vous expliquer les différentes modifications que j'ai fait dans mon code source de base pour pouvoir référencer correctement le site avec la navigation en "AJAX".

Dans un premier temps j'ai utiliser le Framework PHP CodeIgniter : http://www.codeigniter.com

Ensuite j'ai téléchargé la librairie jQuery : http://www.jQuery.com ainsi que le plugin jQuery.History disponible ici : http://www.mikage.to/jquery/jquery_history.html

Par défaut les adresses de Code Igniter sont du genre : /index.php/class/méthode etc... ce qui est vraiment pas optimum pour le référencement j'ai donc décidé de supprimer le "index.php/" pour cela j'utilise un fichier .htaccess avec les paramètres suivants :

RewriteEngine On
RewriteBase /
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME} !-d
RewriteRule ^(.*)$ /index.php?/$1 [L]

Ce qui me permet d'avoir : /accueil/login à la place de : /index.php/accueil/login
Ou d'avoir /accueil à la place de : /index.php/accueil

J'ai créer dans /application/controllers un contrôleur que j'ai nommé "page". Ce contrôleur appellera la page demandé avec un header et un footer.

class Page extends Controller {

	function Page()
	{
		parent::Controller();
	}

	function index()
	{
		// Charge la page : /application/views/accueil.php
		$data['main_content'] = 'accueil';
		$this->load->view('includes/template', $data);
	}

	function contact()
	{
		// Charge la page : /application/views/contact.php
		$data['main_content'] = 'contact';
		$this->load->view('includes/template', $data);
	}

}

Ensuite dans le dossier /application/views j'ai un dossier "includes" qui contient :
header.php

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml"  dir="ltr" lang="en">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
<title></title>
</head>
<body>

template.php

// Header du site
<?php $this->load->view('includes/header'); ?>
// Vue chargé par la variable $main_content
<?php $this->load->view($main_content); ?>
// Footer du site
<?php $this->load->view('includes/footer'); ?>

footer.php

</body>
</html>

Ajouter dans votre htaccess une ligne par page que vous voulez créer à noté on appel toujours "page" qui est notre contrôleur et "accueil" qui est notre méthode ;)

RewriteRule ^accueil$ /index.php/page/accueil/ [L]
RewriteRule ^contact$ /index.php/page/contact/ [L]

Donc on peut créer un menu dans /application/views/includes/header.php

<div id="navigation">
  <ul>
    <li><a href="/accueil">Accueil</a></li>
    <li><a href="/contact">Contact</a></li>
  </ul>
</div>

Ce menu fonctionnera parfaitement avec tous les navigateurs par contre il rechargera a chaque fois tous les éléments : header.php template.php et footer.php

Pour ne pas recharger a chaque fois tous les éléments on peut utilise le plugin jQuery.History. Ce plug in fonctionne avec des liens avec l'attribut rel="history" et avec des ancres donc des liens avec des #page etc...

J'ai donc fait un petit code en jQuery qui modifie le menu précédent par le code :

<div id="navigation">
  <ul>
    <li><a rel="history" href="#accueil">Accueil</a></li>
    <li><a rel="history" href="#contact">Contact</a></li>
  </ul>
</div>

Le script jQuery qui permet de modifier le menu a la volée est le suivant :

    $(document).ready(function() {
        /* Pour chaque element a qui se trouve dans un li dans un ul dans un element id="navigation" */
        $("#navigation ul li a").each(function(){
            /* On recupere le href et on coupe le slash */
            var ancre = $(this).attr("href").split('/');
            /* On ajoute l'attribut rel avec la valeur history */
            $(this).attr("rel","history");
            /* On modifie l'attribut href par le nouveau avec le # a la place du slash */
            $(this).attr("href","#" + ancre[1]);
        });
    });

Si le navigateur accepte jQuery et le Javascript alors les liens seront de la forme #lien et chargé grâce au plugin jQuery History sinon les liens seront de la forme /lien :)

A l'an prochain bon réveillon ;)


CodeIgniter

Depuis quelques temps je me suis mis à utiliser CodeIgniter, un framework PHP.

Pour utiliser CodeIgniter vous devez avoir :
- PHP version 4.3.2 ou supérieur.
- Une base de donnée (optionnel) mais utile lors de la création d'applications ou de sites web tel que : MySQL 4.1 ou supérieur, MySQLi, MS SQL, Postgres, Oracle, SQLite, ou ODBC.

Pour utiliser CodeIgniter télécharger la dernière version sur le site officiel. (Actuellement c'est la version : 1.7.2)
Ensuite décompressez les fichiers et placez les dans le répertoire de votre serveur web. Puis ouvrir le fichier de configuration qui se trouve dans application/config/config.php avec un éditeur de texte pour définir l'url de base de votre site. Vous pouvez également définir votre clé de chiffrement pour vos sessions.
Si vous voulez utiliser les bases de données éditer également le fichier application/config/database.php et définir les différents paramètres de connexion à votre base.

CodeIgniter utilise le modèle MVC "Model View Controler" et il est sous licence BSD.
Je vous invite a voir les différents Cheasheets qui vous permettrons de vous y retrouver au début, ainsi que d'utiliser la documentation disponible en ligne.

Pour commencer également n'hésitez pas a faire un tour dans la rubrique "VideoTutorial" pour voir des tutoriels (dont un qui permet la création d'un blog).

N'hésitez pas a ajouter des commentaires si vous avez des questions ou nous contacter via twitter @point2zero à bientôt !


Protéger un répertoire grâce à un htaccess

Aujourd'hui j'ai voulu protéger un répertoire grâce a un fichier htaccess.

Il y a des centaines de sites qui indiquent comment faire ça de façon simple "créer votre fichier .htpasswd, coller ceci, créer votre htaccess et coller ceci..."

Je créer très souvent des fichiers htaccess / htpasswd de la manière suivante (en ligne de commande) :

Pour savoir ou je me trouve par rapport a la racine de mon serveur j'utilise "pwd" :

$ pwd
/home/sites/www.point2zero.net/exemples

Ensuite je créer mon fichier .htaccess

$ vi .htaccess

Dedans j'ajoute (grâce à la touche i pour passer en mode insertion) :

AuthName "Point2Zero"
AuthType Basic
AuthUserFile "/home/sites/www.point2zero.net/exemples/.htpasswd"
Require valid-user

Le texte de la première ligne sera le message affiché dans ma fenêtre de login.
Dans le AuthUserFile nous allons spécifier le chemin (grâce a la commande précédente pwd) et nous ajoutons à la fin un /.htpasswd qui sera le fichier avec les identifiant et mot de passe.

Sauvez et quitter votre fichier grâce à ":wq"

Maintenant créons le fichier ".htpasswd" grâce à la commande htpasswd :

$ htpasswd -bcm .htpasswd login p4ssw0rd

Détail de la commande :
l'option "b" : permet d'utiliser un fichier pour sauvegarder les informations
l'option "c" : permet de créer le fichier (a enlever lors du 2eme ajout si on veut ajouter plusieurs utilisateurs dans le même fichier)
l'option "m" : permet d'encrypter le mot de passe en MD5
ensuite on indique le fichier, le login et le mot de passe.

Voilà vous savez maintenant sécuriser un dossier grâce à deux fichier htaccess et htpasswd !


Débuter avec Vi, Vim, Gvim

Certaines personnes savent que j'utilise très souvent l'éditeur de texte Vim.

Cet éditeur très puissant (a mon goût) permet de faire tout un tas de choses, sur divers systèmes d'exploitations (Windows, Linux, Mac Os...).

Au début, l'utilisation n'est pas facile mais au fil du temps, on peut se retrouver a faire du copier coller de certains fichier dans d'autres dans une fenêtre (en ssh par exemple).

Vi

Facilement on peut "découper" notre fenêtre en deux par exemple l'une au dessus de l'autre avec la commande ":new"

Pour la "découper" dans l'autre sens pour en avoir deux l'une a côté de l'autre il suffit d'utiliser la commande ":vsplit"

Avec la commande ":vsplit" si un fichier est déjà ouvert il sera ouvert deux fois, tandis qu'avec la commande ":new" une fenêtre vide sera créé.

Pour ouvrir un fichier dans une des fenêtre vide il suffit d'utiliser ":e chemin/fichier" par exemple ":e /home/choiz/fichier.txt".

Pour passer d'une fenêtre a une autre utilisez "ctrl + w, w" ou "ctrl + w, une flèche" pour désigner la fenêtre du haut du bas droite ou gauche.

Pour fermer une fenêtre allez dans celle-ci et utiliser ":q" ou ":wq" si vous voulez sauvegarder le fichier ;)

Plus d'informations sur "le guide de survie VI" et n'hésitez pas a télécharger et ajouter mon fichier de configuration .vimrc à la racine du répertoire utilisateur par exemple /home/choiz :)


MySQL : A quoi sert ci dans utf8_general_ci ?

Vous avez sans doute déjà travaillé avec des bases de données tel que MySQL, PostgreSQL ou autre...

Lors de l'utilisation d'une base MySQL on créer des tables. Dans ces tables nous créons différents champs.

Par exemple sur mon site je veux faire un système d'authentification, je vais donc créer une table "login" avec dedans mes utilisateurs et mots de passe par exemple.

Lors de la création de la table vous avez plusieurs choix déjà le nombre de colonnes pour savoir le nombre de champs :
colonnes

Dans notre cas 3 :
L'id, L'identifiant, Le mot de passe.

Ensuite pour chaque champs nous devons indiquer :
- Un nom (id, login, pass)
- Un type (int, varchar, text etc...)
- La taille ou La valeur par exemple 255 pour un varchar ou par exemple ("yes", "no") si on fait un enum et qu'on veut une réponse prédéfinie
- L'interclassement :

Il comprend :

-> le jeu de caractère (ASCII, UTF8, LATIN1 etc...)
-> l'interclassement ou collation (Swedish, French ...)
-> le "_ci" ou "_cs".

A quoi sert l'interclassement ? Lorsque l'on utilise ORDER BY l'interclassement va en fonction de la langue ordonner différemment les résultats. Donc ça peut être très utile !

Alors qu'est ce que le fameux "_ci", "_cs" "_bin" ?
"_ci" pour Case Insensitive,
"_cs" pour Case Sensitive
"_bin" pour Binaire.

Voici les enregistrements dans ma table :

id login pass
1 ChoiZ 123456
2 choiz azerty
3 cHOIz 654321
4 CHOIZ AzertY
5 test test

Imaginons que vous vouliez sélectionner le champ login dans votre table, si il est en "_ci" :

SELECT password FROM users WHERE login="ChoiZ"
SELECT password FROM users WHERE login="choiz"

retournerons les mêmes résutats soit :
Pour le premier et le second cas les colonnes :

1 ChoiZ 123456
2 choiz azerty
3 cHOIz 654321
4 CHOIZ AzertY

En revanche si "_cs" est utilisé :

SELECT password FROM users WHERE login="ChoiZ"

cette requette retournera uniquement la premiere ligne soit :

1 ChoiZ 123456
SELECT password FROM users WHERE login="choiz"

cette requette retournera uniquement la seconde ligne soit :

2 choiz azerty

J'espère que ce billet vous sera utile dans vos futurs développements.


Faire des commentaires efficaces !

Bonjour,
Voilà une petite astuce que m'as indiqué un ami (Yohann) pour faire des commentaires efficaces.

Prenons un commentaire multiligne tel que :

/* Debut du commentaire
Long commentaire avec beaucoup de lignes...
et même du code PHP tel que
echo"bla bla";
Fin du commentaire */

Si on veut supprimer ce commentaire en gardant notre echo on va devoir fermer le premier commentaire avec */ puis ouvrir le deuxieme avec /* tel que :

/* Debut du commentaire
Long commentaire avec beaucoup de lignes...
et même du code PHP tel que */
echo"bla bla";
/* Fin du commentaire */

Voilà une astuce encore plus simple pour gagner du temps...

/* Debut du commentaire
Long commentaire avec beaucoup de lignes...
et même du code PHP tel que
echo"bla bla";
/* Fin du commentaire */

On ouvre une nouvelle fois un commentaire à la fin permet de gagner du temps ! Entre les lignes de code il suffit juste que j'ajoute un */ devant le "echo" pour fermer le premier commentaire ;)
L'exemple n'est pas très parlant ici mais c'est bien pratique quand c'est bien utilisé !