Modifications entre les versions 4 et 21 (s'étendant sur 17 versions)
Version 4 à la date du 2008-05-29 15:15:58
Taille: 1779
Commentaire: il semble que PHP5 n'ait pas besoin de hack... à vérifier !
Version 21 à la date du 2012-02-13 18:55:12
Taille: 4145
Éditeur: MoussaNombre
Commentaire: 5.1
Texte supprimé. Texte ajouté.
Ligne 14: Ligne 14:
<<Anchor(mysql)>>
Ligne 15: Ligne 16:
 * créer le fichier `/etc/mysql/conf.d/local.cnf` suivant :
{{{
 * créer le fichier `/etc/mysql/conf.d/local.cnf` suivant : {{{
Ligne 18: Ligne 18:
default-character-set = utf8 # l'option suivante semble gêner quelques outils, comme mysqlbinlog
#default-character-set = utf8
Ligne 22: Ligne 23:
default-character-set = utf8
Ligne 29: Ligne 29:
Ligne 30: Ligne 31:
#bind-address = 0.0.0.0

# Les logs
# ATTENTION : Be aware that this log type is a performance killer.
#general_log_file = /var/log/mysql/mysql.log
#general_log = 1
Ligne 31: Ligne 39:
# log_bin = /var/log/mysql/mysql-bin.log

# max_connections = 500
Ligne 42: Ligne 53:
 * relancer ensuite le service MySQL avec : {{{
$ sudo invoke-rc.d mysql restart
}}}

<<Anchor(apache)>>
Ligne 43: Ligne 59:
 * activer le module MIME si ce n'est déjà fait :
{{{
 * activer le module MIME si ce n'est déjà fait : {{{
Ligne 47: Ligne 62:
 * directive globale à ajouter, par exemple, dans `/etc/apache2/conf.d/charset` :
{{{

* directive globale à ajouter dans `/etc/apache2/conf.d/charset` : {{{
Ligne 52: Ligne 67:
 * vérifier que vous avez cette option (au moins) dans `/etc/apache2/mods-available/autoindex.conf`, sinon l'y ajouter : {{{
IndexOptions Charset=UTF-8
}}}

 * vérifier la configuration puis relancer le service Apache avec : {{{
$ sudo apache2ctl configtest
$ sudo apache2ctl graceful
}}}

<<Anchor(python)>>
=== Python ===
 * directive locale à ajouter au début de chaque fichier : {{{#!python
#!/usr/bin/env python
# -*- coding: utf-8 -*-
}}}

 * [[http://docs.djangoproject.com/en/dev/howto/deployment/modpython/#if-you-get-a-unicodeencodeerror|le support des noms de fichiers avec caractères non-ASCII]] :
  * avec [[Debian/Lenny]], ajouter la ligne suivante dans `/etc/apache2/envvars` : {{{
export LC_ALL='fr_FR.UTF-8'
}}}
  * avec [[Debian/Squeeze]], dé-commenter la ligne suivante dans `/etc/apache2/envvars` : {{{
. /etc/default/locale
}}}

<<Anchor(php)>>
Ligne 53: Ligne 93:
 * directive globale à ajouter dans `/etc/php4/apache2/php.ini` :
{{{
 * directive globale à ajouter dans `/etc/php4/apache2/php.ini` : {{{
Ligne 57: Ligne 96:
 * on a parfois besoin de ne l'activer que pour une seule arborescence, par exemple le temps d'une migration, auquel cas on utilisera une configuration Apache de ce genre : {{{
<Location /branche-latin1/>
  AddDefaultCharset iso-8859-1
  php_value default_charset 'iso-8859-1'
</Location>
<Location /branche-unicode/>
  AddDefaultCharset utf-8
  php_value default_charset 'utf-8'
</Location>
}}}

 * vérifier la configuration puis relancer le service Apache avec : {{{
$ sudo apache2ctl configtest
$ sudo apache2ctl graceful
}}}

<<Anchor(smokeping)>>
=== SmokePing ===
 * directive globale à ajouter dans la section `*** Presentation ***` : {{{
template = /etc/smokeping/basepage.html
charset = utf-8
}}}

<<Anchor(ocs)>>
=== OCS-Inventory ===
 * convertir le fichier de traduction en français de `ISO-8859-1` vers `UTF-8` : {{{
mv languages/french.txt languages/french.txt.orig
iconv --from=ISO-8859-1 --to=UTF-8 languages/french.txt.orig > languages/french.txt
sed -i '/^0 /s/iso-8859-1/utf-8/' languages/french.txt
}}}

Ce document présente les configurations à effectuer pour être compatible avec Unicode.

/!\ Attention : passer à Unicode ne se fait pas sur un coup de tête ! Il y a des implications à presque tous les niveaux et une mauvaise mise en place entraînerait au mieux des accents mal affichés et au pire des corruptions de données (typiquement suite à des mixages d'encodages) !

Stratégie

...(reste à écrire)...

Configuration

/!\ Attention : l'ordre est important. En particulier : il faut installer les locales avant tout.

Environnement système

  • installer le paquet locales et choisir une locales UTF-8 par défaut (typiquement fr_FR.UTF-8).

MySQL ≥ 5.0

  • créer le fichier /etc/mysql/conf.d/local.cnf suivant :

    [client]
    # l'option suivante semble gêner quelques outils, comme mysqlbinlog
    #default-character-set = utf8
    
    [mysqld]
    # par défaut du côté serveur
    character-set-server = utf8
    
    # à exécuter pour tous les clients (indispensable pour PHP 4, au moins)
    init-connect = 'SET NAMES utf8'
    
    language = /usr/share/mysql/french
    
    bind-address = 127.0.0.1
    #bind-address = 0.0.0.0
    
    # Les logs
    # ATTENTION : Be aware that this log type is a performance killer.
    #general_log_file        = /var/log/mysql/mysql.log
    #general_log             = 1
    
    # log_slow_queries = /var/log/mysql/mysql-slow.log
    # log_bin = /var/log/mysql/mysql-bin.log
    
    # max_connections = 500
    
    [mysqldump]
    # est-ce vraiment utile ? *** À TESTER ***
    default-character-set = utf8
    
    [mysql]
    # par défaut du côté client (pour root, qui ne subit pas le init-connect)
    default-character-set = utf8
  • relancer ensuite le service MySQL avec :

    $ sudo invoke-rc.d mysql restart

Apache ≥ 2.0

  • activer le module MIME si ce n'est déjà fait :

    sudo a2enmod mime
  • directive globale à ajouter dans /etc/apache2/conf.d/charset :

    AddDefaultCharset UTF-8
  • vérifier que vous avez cette option (au moins) dans /etc/apache2/mods-available/autoindex.conf, sinon l'y ajouter :

    IndexOptions Charset=UTF-8
  • vérifier la configuration puis relancer le service Apache avec :

    $ sudo apache2ctl configtest
    $ sudo apache2ctl graceful

Python

  • directive locale à ajouter au début de chaque fichier :

       1 #!/usr/bin/env python
       2 # -*- coding: utf-8 -*-
    
  • le support des noms de fichiers avec caractères non-ASCII :

    • avec Debian/Lenny, ajouter la ligne suivante dans /etc/apache2/envvars :

      export LC_ALL='fr_FR.UTF-8'
    • avec Debian/Squeeze, dé-commenter la ligne suivante dans /etc/apache2/envvars :

      . /etc/default/locale

PHP

  • directive globale à ajouter dans /etc/php4/apache2/php.ini :

    default_charset = "utf-8"
  • on a parfois besoin de ne l'activer que pour une seule arborescence, par exemple le temps d'une migration, auquel cas on utilisera une configuration Apache de ce genre :

    <Location /branche-latin1/>
      AddDefaultCharset iso-8859-1
      php_value default_charset 'iso-8859-1'
    </Location>
    <Location /branche-unicode/>
      AddDefaultCharset utf-8
      php_value default_charset 'utf-8'
    </Location>
  • vérifier la configuration puis relancer le service Apache avec :

    $ sudo apache2ctl configtest
    $ sudo apache2ctl graceful

SmokePing

  • directive globale à ajouter dans la section *** Presentation *** :

    template = /etc/smokeping/basepage.html
    charset = utf-8

OCS-Inventory

  • convertir le fichier de traduction en français de ISO-8859-1 vers UTF-8 :

    mv languages/french.txt languages/french.txt.orig
    iconv --from=ISO-8859-1 --to=UTF-8 languages/french.txt.orig > languages/french.txt
    sed -i '/^0 /s/iso-8859-1/utf-8/' languages/french.txt

Etude/Unicode (dernière édition le 2021-03-23 05:33:53 par JeanChristopheAndré)