|
Publicité ' | ||||||||||||||||||||||||
|
|
#1 | ||||
|
Membre du Club
![]() Inscription : septembre 2005 Messages : 224 ![]() |
Bonjour
ma question et la suivante : Comment bien programmer en PHP ? Donc si vous avez des conseils, des truc à utiliser/éviter et d'autres choses. Par exemple : Code le plus court : Code :
Code :
|
||||
|
|
10
|
|
|
#2 |
![]() ![]() Thierry GodinDéveloppeur Web Inscription : janvier 2003 Messages : 2 138 ![]() |
Bonjour,
pour ma part : - Bien indenter le code pour une meilleure lisibilité - Bien commenter le code , même si ça prend du temps. Tu seras content dans 6 mois d'avoir pris le temps de commenter ton code . . . |
|
10
|
|
|
#3 | ||||
|
Expert Confirmé
![]() |
Salut!
• Toujours bien mettre en place un algo, voir un cahier des charges bien pensé avant de se plonger dans le code. Pour cette étape, il est important de connaître les règles de sécurité, quelles peuvent être les failles : http://php.developpez.com/faq/?page=securite • Perso, je sépare bien les "unités" de mon programme, par exemple : cfg.php // Constante et variable de configuration bbd.php // Fonctions d'accès à la base de données func.php // Diverses fonctions, conversion, traitement mail.php // Fonctions d'envoi de mail forms.php // Formulaires html de saisie etc... J'inclus les unités les unes aux autres avec Require_once(). • J'utilise les tableaux pour les constantes, variables, données... et la commande global pour les intégrer dans mes fonctions. Par exemple, dans le script "cfg.php", tu trouveras : Code :
Code :
• J'utilise les simples quotes dans tous les cas, excepté pour encadrer les requêtes SQL où j'utilise les doubles quotes, car avec mon editeur PHP, il est possible de choisir une couleur différente. Ainsi, je repère tout de suite où se trouvent les requêtes SQL. • J'utilise de péréférence des "echo" pour intégrer du code HTML, CSS ou Javascript dans mes scripts PHP. J'évite de fermer les balises PHP (?>) ou sinon, je mets tout le code HTML, CSS ou Javascript dans un autre fichier. • Bien garder à l'esprit que ton code sera probablement lu par d'autres développeurs. |
||||
|
|
10
|
|
|
#4 |
|
Membre du Club
![]() Inscription : septembre 2005 Messages : 224 ![]() |
Merci
Donc est ce qu'il y a des normes à suivre, parce que parfois on arrive à des situations ambiguës (usine a gaz). Par contre en java il existe plusieurs solutions permettant de structurer la programmation. Donc si vous avez des exemples d’architecture ou des projets (perso) qui se base sur des architectures (MVC par exemple). |
|
|
00
|
|
|
#5 |
|
Expert Confirmé
![]() |
|
|
|
00
|
|
|
#6 | ||
|
Membre chevronné
![]() Inscription : novembre 2003 Messages : 736 ![]() |
Il vaut mieux toujours privilégier l'optimisation.
Par exemple les chaines de caractères avec des simples quotes et non pas des doubles. (Ne pas avoir la fleme de concaténer les variables). Exemple : Code :
Separer au maximum les fichiers selons leur context et non pas faire un fichier de function tout bordélique.
__________________
http://www.ape-project.org/ |
||
|
00
|
|
|
#7 | ||
|
Membre du Club
![]() Inscription : septembre 2005 Messages : 224 ![]() |
merci
On peut généraliser le sujet un petit peu Code :
|
||
|
|
00
|
|
|
#8 | |
![]() ![]() Marc ChappuisDéveloppeur Web Inscription : décembre 2003 Messages : 1 562 ![]() |
Citation:
qu'une optimisation n'est nécessaire que si il y a un besoin réel et pas juste hypothétique. J'ai souvent pensé qu'un code optimisé était en sois meilleur. Mais il est souvent moins clair, plus difficile à maintenir, et il arrive qu'il soit remplacé par un nouveau produit avant même d'avoir atteint ses limites. Mais il est vrai, que c'est un vrai plaisir d'optimiser son code... mais on devrait le faire que lorsqu'il s'avère que c'est économiquement nécessaire et pas avant !
__________________
Si ton code fait plus d'une ligne, c'est que tu as mal choisi ton langage ! |
|
|
|
20
|
|
|
#9 |
![]() ![]() Développeur Web Inscription : juillet 2003 Messages : 683 ![]() |
Voila un sujet que j'aime mettre mon grain de sel dedans
![]() Pour moi, clairement lisibilité à l'échelle de l'architecture, optimisation au niveau plus atomique. Car
Cependant, quelques points esentiels pour moi : Un fichier doit être soit: - une page (donc directement/indirectement appelable depuis une url) - une classe (et une seule par fichier) - une config. Les fichiers "placards", je trouve ça pas propre. En général, je n'en fait qu'un, qui regroupe les points communs à chaque pages (inclusion des classes, autoload, récup des configs, objet $db...) et éventuellement un fichier de fonctions avec vraiment l'inclassable. L'important ensuite est de respecter la POO, genre l'encapsulation des données. Une séparation nette de la vue est obligatoire. Ecrire directement du code HTML dans du PHP ou inversement, c'est pas propre et intenable. L'utilisation de fonctions soigne un peu cet aspect, mais au final, ça reste du HTML dans du PHP, d'autant plus que l'encapsulation des données, ça compte aussi pour une fonction et qu'un echo, c'est une sortie comme une autre. (d'ailleurs, vaut mieux éviter les global dans les fonctions et y préferer le singleton, en utilisant non pas des tableaux pour la config, mais des objets conteneurs (style Entity de java)). Bref, pour la vue, des templates, ou mieux (mais quand même plus compliqué) le couple XML/XSLT. Bon oki, je n'applique pas à la lettre absolument tout ce que je dit, mais j'essaie au mieux. Pour répondre à Fadex, il existe le fameux MVC (Modèle vue contrôleur) qui consiste à séparer ces 3 couches. La vue j'en ai parlé au dessus. Le modèle correspond en gros à tes données et donc ton accès à la base dans ton cas. Ca signifie globalement que ton script n'a pas à savoir d'ou viennent ces données, et donc il ne faut pas utiliser de fonction spécifique à telle ou telle base, mais une classe. Ainsi au lieu de mysql_query, tu auras $db->query. Si ta base devient Postgresql, au lieu de pq_query, tu aura tjs $db->query, mais avec un $db différent. Il te suffit de changer le fichier contenant la déclaration de $db et hop, t'as changer de base. Bon, j'arrete avant d'écrire un livre.
__________________
Articles sur developpez.com - Gestion des exceptions avec PHP5 - Chiffrement et hash en PHP contre l'attaque Man in the middle - Aedituus - Espace membre sécurisé en PHP5 Lithium : ORM ActiveRecord PHP5 extrêmement léger |
|
00
|
|
|
#10 | |
|
Membre du Club
![]() Inscription : septembre 2005 Messages : 224 ![]() |
voila ce que je cherche
Citation:
Mais comment appliquer l'architecture MVC dans un projet PHP ? J’ai des petites expériences avec J2EE, mais ça reste pour moi une usine à gaz , oui c vrais qu’il y a beaucoup de doc mais ça reste de la théorie.Donc est ce que vous avez un tuto ou un site qui explique comment mettre en place cette architecture. Je t’encourage pour terminer le livre [edit]voila ce que j'ai trouvé : PHPMVC[/edit] |
|
|
|
00
|
|
|
#11 | |
![]() ![]() Développeur Web Inscription : juillet 2003 Messages : 683 ![]() |
D'une façon très simple, la vue, c'est un template (comme Smarty), ou la classe de PHPLib modifiée par PHPBB qui est très utilisée, par moi notamment
Pour aller plus loin, il y a des frameworks comme le Zend Framework et pleins d'autres en fait. Va donc faire un tour ici http://tahe.developpez.com/web/php/mvc/ PS : Citation:
![]()
__________________
Articles sur developpez.com - Gestion des exceptions avec PHP5 - Chiffrement et hash en PHP contre l'attaque Man in the middle - Aedituus - Espace membre sécurisé en PHP5 Lithium : ORM ActiveRecord PHP5 extrêmement léger |
|
|
00
|
|
|
#12 | |
|
Membre Expert
![]() Inscription : septembre 2002 Messages : 1 691 ![]() |
Citation:
L'utilisation de template simplifie vraiment le code. |
|
|
|
00
|
|
|
#13 |
|
Membre habitué
![]() Inscription : juin 2006 Messages : 133 ![]() |
Et puis un petit point de détail comme ça que je connais :
Utiliser : Plutôt que Il y a seulement une différence de quelques millièmes de secondes à la lecture, c'est rien du tout, mais puisqu'on est dans l'optique d'optimiser le code autant le faire, ça coute 3 lettres à rajouter. |
|
|
00
|
|
|
#14 | |
|
Membre chevronné
![]() Inscription : novembre 2003 Messages : 736 ![]() |
Citation:
__________________
http://www.ape-project.org/ |
|
|
00
|
|
|
#15 | |
![]() ![]() Inscription : juin 2003 Messages : 4 892 ![]() |
Citation:
__________________
Modérateur PHP |
|
|
|
00
|
|
|
#16 |
|
Membre du Club
![]() Inscription : septembre 2005 Messages : 224 ![]() |
Bonjour
j'ai trouvé un article très intéressant sur le developpement Objet sous PHP, en se basant sur l'architecture mvc. avec un generateur de class. PHPBuilder donnez moi votre avis |
|
|
00
|
|
|
#17 |
|
Expert Confirmé
![]() Inscription : octobre 2003 Messages : 2 723 ![]() |
Salut,
Je pense que le plus important dans une application PHP, ou les scripts sont à chaque appel "recompilés", il est vital d'avoir une base de données optimisée. Il faut mettre des index aux endroits où c'est le plus important, et avoir un modèle efficace afin que les requêtes ne soient pas un gouffre de performance. Utiliser des fichiers plats pour les définitions redondantes et simples de l'application parrait être un plus pour éviter d'encombrer la base de données avec des requêtes à tout va. Je ne connais pas bien Zend, mais si j'ai bien compris ils proposent une précompilation qui peut grandement accélerer php, et le rendre compétitif face à ces langages d'applications comme Java et C# qui bénéficient par nature d'une précompilation ( même si ce n'est pas du natif, les performances sont au rendez-vous ). De plus, un système de cache semble primordial, comme celui proposé par CakePHP. D'ailleurs je vous conseille de jeter un oeil à ce framework, qui parrait plutôt prometteur malgré son nom A+
__________________
K |
|
|
00
|
|
|
#18 | |
![]() ![]() Inscription : juin 2003 Messages : 4 892 ![]() |
Citation:
__________________
Modérateur PHP |
|
|
|
00
|
|
|
#19 |
|
En attente de confirmation mail
|
Bien programmer pour moi, c'est :
- Bien indenter son code, - Ne pas prévilégier la vitesse d'exécution (sinon utiliser un cache), - Tester, re-tester, re-re-tester... son code, - Sécuriser son site au maximum, - Utiliser que la POO, - Bien commenter, - Avoir une "bonne architecture" du site... (site ordonné) Pour cela moi j'utilise Zend Studio (la version pro) qui est excellent, surtout son gestionnaire de projets. Il vaut vraiement le coup. Personnellement, la version standard me suffit largement... (ce magnifique prog appartient à mon frère, bon ben là je vous raconte un peu ma vie... ) Son débuggeur est vraiment très utile et très puissant ! Téléchargez la version d'évaluation et vous allez voir !La moyenne de la vitesse d'exécution de mes scripts est de 0,0021s, voir même 0,001s (en plus sur ma machine avec 500 programmes d'ouverts...). Moi j'utilise un fichier index (int.php) qui inclut tous les autres fichiers et une sorte de mini-noyau pour le site autour duquel sont montés tous les autres "programmes". Je suis en train de le développer... |
|
|
00
|
|
|
#20 |
|
Membre confirmé
![]() ![]() |
Avec l'expérience, bien coder, c'est éviter au maximum de refaire le boulot 200 fois...
Qui n'a pas du réécrire pour la xème fois le code pour afficher une GridView (désolé, ce terme existe pas en php, mais ceux venant d'autres langages comprendront) pour une interface de gestion? Qui n'a pas du rechercher son code pour une identification, ou un panier sécurisé, ou un système de news? Maintenant, je tends de plus en plus vers une optimisation, et donc la création de classe. Mais surtout, la création de classes personnalisées. Qui n'a pas été content de pouvoir récupérer 1 semaines de codage dans 12 dossiers car ca à été fait une fois de facon correcte? Le vrai pied. Après, coder, c'est avant tout comprendre son code, et pouvoir le relire, meme dans 6 ans. Donc pour ca: - identation - commentaire - utilisation de variable logique (non, $temp pour un tableau, c'est pas un nom inteligent...) - Séparer le contenu du contenant. Quoi de plus beau qu'une page ne contenant QUE du PHP? En laissant nos fonctions ou notre framework gérer l'affichage? En tout cas, pour le dépannage, ou les gros site, c'est un vrai bonheur! - Et comme précisé... Si vous faites encore du bon vieux php4, intéressez-vous sincèrement a l'orienté objet et au PHP5. C'est non seulement un gain de temps, mais de lisibilité ! Onet |
|
|
00
|
Copyright © 2000-2013 - www.developpez.com