Différences entre versions de « PHP »

De Cliss XXI
Sauter à la navigation Sauter à la recherche
imported>SylvainBeucler
m
imported>SylvainBeucler
 
(Une version intermédiaire par le même utilisateur non affichée)
Ligne 13 : Ligne 13 :
 
* http://www.j2eegeek.com/blog/2007/02/27/php-acceleration-pick-your-poison/ (APC)
 
* http://www.j2eegeek.com/blog/2007/02/27/php-acceleration-pick-your-poison/ (APC)
  
== Dernière version libre de la documentation PHP ==
+
== Documentation PHP - évolution de la licence ==
  
Dernières versions de la documentation officielle de PHP, avant qu'elle ne devienne non-libre:
+
Il y a eu différents changements de licence:
* [http://packages.debian.org/stable/doc/php3-doc Documentation for PHP3]
+
* date < 2003-05-02: GNU GPL v2+
* [http://packages.debian.org/oldstable/doc/phpdoc Documentation for PHP4 and PHP3] (snapshot 2002)
+
* 2003-05-02 < date < 2008-07-20: OPL avec options non-libres de non-modification et de non-distribution sous forme papier
 +
* 2008-07-20 < date: Creative Commons Attribution 3.0 (cc-by)
  
Précisons que l'Open Publication License (OPL) est une licence libre uniquement si aucune option n'est utilisée (notamment, l'interdiction des travaux dérivés sans consentement des détenteurs des droits).
+
La dernière version de la documentation est donc de nouveau sous licence libre.
  
La dernière version date de 2003.
+
Pour référence, avec <code>cvs2cl --utc</code>, j'obtiens le ChangeLog suivant:
 
 
Avec <code>cvs2cl --utc</code>, j'obtiens le ChangeLog suivant:
 
 
  2003-05-02 14:12  goba
 
  2003-05-02 14:12  goba
 
   
 
   
 
         * en/bookinfo.xml: And now: upgrading to the new license
 
         * en/bookinfo.xml: And now: upgrading to the new license
  
La dernière version libre est donc:
+
La dernière version sous GNU GPL est donc:
 
  cvs -d :pserver:cvsread@cvs.php.net:/repository login # pass: phpfi
 
  cvs -d :pserver:cvsread@cvs.php.net:/repository login # pass: phpfi
  cvs -d :pserver:cvsread@cvs.php.net:/repository checkout -D "2003-05-02 14:12:58Z" phpdocs
+
  cvs -d :pserver:cvsread@cvs.php.net:/repository checkout -D "2003-05-02 14:12:58Z" phpdoc
  
 
== PEAR ==
 
== PEAR ==

Version actuelle datée du 30 janvier 2009 à 15:52

Débogage PHP

Voir la section dédiée: Débogage PHP

Accélérateurs PHP

  • XCache: cache, couverture (optionnel), orienté stabilité, interface web de stats (paquet Debian)
  • APC: cache uniquement (optimiseur obsolète?), plus proche de PHP (participation de Rasmus) (paquet Debian)
  • eAccelerator: successeur de Turck mmCache, fournit aussi encodeur, optimiseur, système de cache pour développeur?...

Comparatifs:

Documentation PHP - évolution de la licence

Il y a eu différents changements de licence:

  • date < 2003-05-02: GNU GPL v2+
  • 2003-05-02 < date < 2008-07-20: OPL avec options non-libres de non-modification et de non-distribution sous forme papier
  • 2008-07-20 < date: Creative Commons Attribution 3.0 (cc-by)

La dernière version de la documentation est donc de nouveau sous licence libre.

Pour référence, avec cvs2cl --utc, j'obtiens le ChangeLog suivant:

2003-05-02 14:12  goba

        * en/bookinfo.xml: And now: upgrading to the new license

La dernière version sous GNU GPL est donc:

cvs -d :pserver:cvsread@cvs.php.net:/repository login # pass: phpfi
cvs -d :pserver:cvsread@cvs.php.net:/repository checkout -D "2003-05-02 14:12:58Z" phpdoc

PEAR

Problèmes de license:

Installation de la version officielle avec les chemins d'accès Debian

Installation de Pear:

aptitude install php5-cli
wget -O- http://pear.php.net/go-pear | php -q

PEAR, configuration implicite:

 1. Installation prefix ($prefix) : /root
 2. Temporary files directory     : $prefix/temp
 4. PHP code directory ($php_dir) : $prefix/PEAR

Pour Debian, modifier:

 1. Installation prefix ($prefix) : /usr
 2. Temporary files directory     : /tmp/pear/temp
 4. PHP code directory ($php_dir) : $prefix/share/php

Résultat final:

PEAR executables directory     bin_dir          /usr/bin
PEAR documentation directory   doc_dir          /usr/share/php/docs
PHP extension directory        ext_dir          /usr/lib/php5/20060613+lfs
PEAR directory                 php_dir          /usr/share/php
PEAR Installer cache directory cache_dir        /tmp/pear/cache
PEAR data directory            data_dir         /usr/share/php/data
PEAR Installer download        download_dir     /tmp/pear/cache
PEAR Installer temp directory  temp_dir         /tmp/pear/temp
PEAR test directory            test_dir         /usr/share/php/tests

Tests unitaires avec PHP

Voir également WWW::Mechanize (Mech) pour tester le programme de manière externe par son interface web (en Perl). Pour une solution en PHP, voir éventuellement la bibliothèque curl, qui ne sait cependant pas analyser le HTML reçu.

Génération de formulaires

Abstraction de la base de données

  • MDB2: successeur de PEAR::DB, licence mBSD
  • Creole: PHP5 seulement; licence LGPL
  • AdoDB: utilisé par TikiWiki, Xaraya, eGroupWare; license mBSD

Simplification de l'accès à la base

Dépend d'une des abstraction ci-dessus. Mots-clefs à chercher: ORM (Object Relational Mapping)

  • DB_Table: non-object, intégration avec QuickForm et validation des update/insert, description via une classe et des tableaux ($cols, $idx, $sql...); utilise PEAR::DB (licence PHP); LGPL
  • Propel: description en XML (lourd?), relations inter-classes, relations N-M possibles mais pas encore propres; possibilité d'utiliser directement SQL si besoin; validation décrite en XML (lourd); utilise Creole
  • DB_DataContainer: mapping objet simpliste, pas de relation inter-tables; description via la classe PHP; nécessite un champ 'id'.
  • DB_DataObject: fichier de description .ini; liens entre classes; à essayer; licence PHP
  • EZPDO: description inclue dans des tags @orm style javadoc; validation via des 'Events'/hooks, aucune validation par défaut a priori; mBSD
  • CakePHP: framework style Ruby on Rails, inclut un ORM; la validation, à base de regexp, fait partie du framework et en est vraisemblablement indissociable.
  • Doctrine: ça a l'air très propre (bonne gestion du model relationel?); description par une classe; discussions en cours pour intégration dans PEAR
  • MetaL Metastrorage: beaucoup de XML
  • ADOdb Active Record: un ORM qui fait partie d'ADOdb, à voir; réimplémentation de Zend Active Records; c'est apparement le seul outil à utiliser la base de données comme description du modèle - ce qui me semble en fait très pertinent.
  • d'autres listés sur Wikipedia.