Ceci est une ancienne révision du document !


oooooooh la la ooooooooh lalal oooooooooooooooooooh la la oooh lala

way yen way yen zi $¶¶õj$&$ã☺⌂8ÏCãÃ0ã«♫$¶¶õj$&$ã☺⌂8ÏCãÃ0ã«♫$¶¶õj$&$ã☺⌂8ÏCãÃ0ã«♫$¶¶õj$&$ã☺⌂8ÏCãÃ0ã«♫$¶¶õj$&$ã☺⌂8ÏCãÃ0ã«♫$¶¶õj$&$ã☺⌂8ÏCãÃ0ã«♫$¶¶õj$&$ã☺⌂8ÏCãÃ0ã«♫$¶¶õj$&$ã☺⌂8ÏCãÃ0ã«♫$¶¶õj$&$ã☺⌂8ÏCãÃ0ã«♫$¶¶õj$&$ã☺⌂8ÏCãÃ0ã«♫$¶¶õj$&$ã☺⌂8ÏCãÃ0ã«♫$¶¶õj$&$ã☺⌂8ÏCãÃ0ã«♫

Association avec un serveur de base de données

PHP permet de se connecter à différents types de serveurs de base de données. Il est cependant nécessaire d'installer des modules complémentaires.

Il est important de souligner que l'installation d'un de ces modules PHP est indépendant de l'installation du serveur de base de données correspondant.

Support de MySQL et MariaDB

Le support de MySQL ou MariaDB par PHP se fait via l'installation du paquet php-mysql.

Un serveur associant Linux, Apache, MySQL et PHP est généralement appelé serveur "LAMP".

Support de PostgreSQL

Le support de PostgreSQL par PHP se fait via l'installation du paquet php-pgsql.

Un serveur associant Linux, Apache, PostgreSQL et PHP est généralement appelé serveur "LAPP".

Support de SQLite

Le support de SQLite par PHP se fait via l'installation du paquet php-sqlite.

Support de Sybase / MS SQL server

Le support de Sybase / MS SQL server par PHP se fait via l'installation du paquet php-sybase.

Installation des modules complémentaires

Voir la page dédiée aux modules PHP.

La configuration de PHP se fait via un fichier php.ini.

Pour le module PHP d'Apache, le chemin d'accès au fichier php.ini sera généralement :

  • sous Ubuntu 14.04 : /etc/php5/apache2/php.ini
  • sous Ubuntu 16.04 : /etc/php/7.0/apache2/php.ini

Les fichiers de configuration ne sont pas les mêmes pour utiliser PHP en ligne de commande (cli pour command-line interface) : /etc/php/7.0/cli/php.ini
ou en script FastCGI (fpm pour FastCGI Process Manager) : /etc/php/7.0/fpm/php.ini

Ceci explique parfois des différences de comportement entre PHP exécuté par Apache, et manuellement en ligne de commande.

Activer le rapport d'erreur

Si vous développez une application en local, il est souvent utile de visualiser les messages d'erreurs directement sur votre page web. Ces erreurs sont cependant généralement aussi accessibles dans le journal d'erreur du serveur HTTP (/var/log/apache2/error.log pour Apache).

Pour afficher les erreurs, avec Apache vous pouvez par exemple définir des règles dans un fichier .htaccess à la racine de votre hôte virtuel :

.htaccess
php_flag display_errors=on
php_flag error_reporting=E_ALL

error_reporting définit le niveau d'erreur que vous souhaitez afficher.

Le niveau d'erreur E_ALL affiche toutes les erreurs, y compris celles concernant des fonctionnalités dépréciées (qui seront désactivées dans des versions futures de PHP) ou des erreurs strictes, qu'on n'a pas forcément envie de corriger.
On peut désactiver l'affichage de ces messages pas toujours très importants en remplaçant cette ligne par celle-ci :

php_flag error_reporting=E_ALL & ~E_NOTICE & ~E_STRICT

Les directives display_errors et error_reporting sont aussi accessibles pour définir l'affichage des erreurs globalement, directement dans votre fichier php.ini.
Pour PHP 7.0 :

/etc/php/7.0/apache2/php.ini
...
display_errors=on
error_reporting=E_ALL & ~E_NOTICE & ~E_STRICT
...

Désactiver le rapport d'erreur

Pour un site en production, mieux vaut désactiver l'affichage des erreurs et se référer uniquement au log d'erreur du serveur HTTP :

.htaccess
php_flag display_errors=off
  • php.1523349156.txt.gz
  • Dernière modification: Le 10/04/2018, 10:32
  • par 161.106.4.5