Archive for the ‘Code’ Category

Envoyer des courriels en SMTP via Gmail avec PHPMailer

February 25th, 2010 / by Dominic / 2 comments

Après avoir passé à Google Apps, j’ai cherché comment envoyer des courriels en SMTP via Gmail à partir d’un script PHP. Voici la solution avec PHPMailer:

require_once "class.phpmailer.php";

$mailer = new PHPMailer();

$mailer->IsSMTP();  // telling the class to use SMTP
$mailer->Username = "username"; // gmail username
$mailer->Password = "password"; // gmail password
$mailer->Host = "smtp.gmail.com"; // SMTP server
$mailer->Port = 465;
$mailer->SMTPSecure = 'ssl';
$mailer->SMTPAuth = true;

$mailer->FromName = "From";
$mailer->From = "from@example.com";
$mailer->AddAddress("to@example.com");

$mailer->Subject  = "My SMTP message with Gmail";
$mailer->Body     = "Hello world!";
$mailer->WordWrap = 50;

if (!$mailer->Send()) {
    echo 'Message was not sent.';
    echo 'Mailer error: ' . $mailer->ErrorInfo;
} else {
    echo 'Message has been sent.';
}

Optimisations de base

January 27th, 2010 / by Dominic / 5 comments

Il n’y a pas de problème de performance tant qu’il n’y a pas de problème de performance. Néanmoins, lorsque je développe un nouveau site, il y a toujours quelques trucs de base que je fais.

Je conseille fortement l’installation de l’extension Yslow sous Firefox. Cette extension analyse votre page et vous suggère des façons d’améliorer les performances de celle-ci basé sur certaines règles de base. Vous y retrouverez les suggestions ci-dessous…

1. Ajouter une date d’expiration aux fichiers statiques

En ajoutant une date d’expiration dans le futur à vos fichier statiques (css, js, png, gif, jpg), cela évite aux navigateurs de retélécharger chaque fichier inutilement à chaque page vue. Ce code doit être ajouté dans un .htaccess.

  <FilesMatch "\.(js|css|gif|jpg|png)$">
     ExpiresActive On
     ExpiresDefault "access plus 10 years"
  </FilesMatch>

L’effet de bord est que si vous modifiez un de vos fichiers statiques, la modification ne sera pas pris en compte par le navigateur ayant déjà celui en cache. La solution est de simplement ajouter une version dans le url du fichier…

Fonction pour ajouter automatiquement une version

Vous pouvez toujours gérer manuellement le versionning ou encore, écrire une fonction qui génère une url avec version à partir de la date de modification du fichier.

/**
  * Return file url with version
  *
  * @param string $filename
  * @return string file url with version
  *
  */
function version($filename) {

  // Get file's version
  $version = filemtime(ABSPATH.$filename);

  return APP_URL.$filename."?v=".$version;

} // version()

n.b: ABSPATH correspond à la racine de votre projet et APP_URL correspond au URL de votre projet à la racine aussi.


2. Compresser le contenu

En compressant votre contenu avec Gzip, vous devriez réduire de 20% à 30% la taille des fichiers, donc moins de bandwith et plus rapide à télécharger par vos utilisateurs.

Assurez-vous que le module deflate soit actif sous Apache… Dans un terminal, effectuez la commande suivante:

a2enmod deflate

Et redémarrer Apache…

/etc/init.d/apache2 restart

Si vous êtes sur un hébergeur payant tel que MediaTemple ou iWeb, ce module est assurément actif. Par la suite, via un .htaccess, ajoutez les lignes suivantes:

AddOutputFilterByType DEFLATE text/plain
AddOutputFilterByType DEFLATE text/html
AddOutputFilterByType DEFLATE text/xml
AddOutputFilterByType DEFLATE text/css
AddOutputFilterByType DEFLATE application/xml
AddOutputFilterByType DEFLATE application/xhtml+xml
AddOutputFilterByType DEFLATE application/rss+xml
AddOutputFilterByType DEFLATE application/javascript
AddOutputFilterByType DEFLATE application/x-javascript

3. Compresser vos fichiers CSS

Encore une fois, plus les fichiers sont petit, mieux c’est. Je m’assure toujours de compresser les fichiers CSS de base de mes projets. À l’aide d’un script shell, j’enlève toutes les espaces inutiles et je réduis les styles sur une seule ligne.

Dans un script shell…

cat $1 | sed -e 's/^[ \t]*//g; s/[ \t]*$//g; s/\([:{;,]\) /\1/g; s/ {/{/g; s/\/\*.*\*\///g; /^$/d' | sed -e :a -e '$!N; s/\n\(.\)/\1/; ta' > $2

Et maintenant, éxécutez la commande suivante:

$> ./minify-css in.css out.css

Vous devriez normalement réduire vos fichier CSS de 10 à 15%.

4. Compresser vos fichiers javascript

Il existe plusieurs compresseur javascript. J’aime bien JSMin de Douglas Crockford.

require 'jsmin.php';
echo JSMin::minify(file_get_contents('main.js'));

Lorsqu’il y a plus de 1 fichier javascript dans une page, le plus possible, tentez de les compresser en un seul fichier. Moins de requêtes sur votre serveur, plus de performance.

Client PHP5 pour Twitter

April 5th, 2009 / by Wibeset / 0 comment

Mini client PHP5 pour mettre à jour votre statut sur Twitter:

<?php

/**
 * Twitter client
 *
 * @see Twitter
 * @see Twitter API documentation
 *
 */

class twitter {

  protected $url = "http://twitter.com/";

  /**
   * cURL instance
   */
  protected $ch = null;

  /**
   * Authentication
   */
  protected $username = '';
  protected $password = '';
  protected $authentication = '';

  /**
   * Constructor
   */
  public function __construct() {
    $this->ch = curl_init();
    curl_setopt($this->ch, CURLOPT_RETURNTRANSFER, 1);
    curl_setopt($this->ch, CURLOPT_HEADER, 0);
    curl_setopt($this->ch, CURLOPT_VERBOSE, 0);
  } // __construct()

  /**
   * Destructor
   */
  public function __destruct() {
    curl_close($this->ch);
  } // __destruct()

 /**
   * Set user authentication
   *
   * @param username (string)
   * @param password (string)
   *
   */
  public function set_authentication($username, $password) {

    $this->username = $username;
    $this->password = $password;
    $this->authentication = $this->username.':'.$this->password;

  } // set_authentication()

  /**
   * Update the authenticating user's status
   * Authentication must be setted.
   *
   * @param status_text (string) new user's status
   *
   */
  public function update($status_text) {

    curl_setopt($this->ch, CURLOPT_URL, $this->url."statuses/update.json");
    curl_setopt($this->ch, CURLOPT_USERPWD, $this->authentication);
    curl_setopt($this->ch, CURLOPT_POST, 1);
    curl_setopt($this->ch, CURLOPT_POSTFIELDS, array('status' => $status_text));

    $result = curl_exec($this->ch);

    return json_decode($result, true);

  } // update()

} // twitter

Demo:

 $twitter = new twitter();
  $twitter->set_authentication('username', 'password');
  $twitter->update('hello from my new php5 client :)');

Pré-requis: cURL enabled et PHP >= 5.2.0

Highlighter son code dans un billet…

March 27th, 2009 / by Wibeset / 0 comment

J’ai découvert récemment un petit plugin JavaScript vraiment cool qui permet d’highlighter du code. D’ailleurs, je l’ai utilisé pour la première fois dans le billet “Obtenir un permalink en JavaScript“.

Ce plugin supporte les langages suivant: C++, PHP, Javascript, CSS, C#, Delphi, Java, Python, Ruby, Sql, VB et XML/HTML.

Google Syntax Highlighter

Un court aperçu Php:

  <?php

  // Best PHP script I ever made ;)
  echo 'Hello world!';

Obtenir un permalink en JavaScript

March 27th, 2009 / by Wibeset / 0 comment

La fonction to_permalink() est une simple fonction JavaScript qui vous permettra de transformer une string en permalink.

/**
 * Return string as permalink
 */
function to_permalink(str) {

  // remove accent
  str = str.replace(/[?| âä]/gi,"a");
  str = str.replace(/[éèêë]/gi,"e");
  str = str.replace(/[îï]/gi,"i");
  str = str.replace(/[ôö]/gi,"o");
  str = str.replace(/[ùûü]/gi,"u");

  // remove special chars
  str = str.replace(/[^a-z0-9_]/gim, "_").replace(/[_+]/gi, "_");

  return str;
}

Un exemple…


  var str = "Je suis le titre d'un article époustouflant!";

  // Retournera le permalink 'Je_suis_le_titre_dun_article_epoustouflant'
  var permalink = to_permalink(str);