-
Info version PHP
Forum : Général
Dernier message : jce76350
15/08/2024, 22:22:19
» Réponses : 174
» Affichages : 281,911 -
[HORS SUJET] Appli foncti...
Forum : Installation
Dernier message : Christian
15/08/2024, 14:19:55
» Réponses : 6
» Affichages : 348 -
Version 2.2.22
Forum : Général
Dernier message : jce76350
11/08/2024, 09:58:43
» Réponses : 2
» Affichages : 752 -
fatal error lors de l'ins...
Forum : Installation
Dernier message : jce76350
11/08/2024, 09:50:01
» Réponses : 3
» Affichages : 332 -
Cherche testeurs pour V 2...
Forum : Général
Dernier message : jce76350
20/07/2024, 21:08:42
» Réponses : 87
» Affichages : 44,231 -
Version 2.2.21
Forum : Général
Dernier message : jce76350
13/07/2024, 10:09:35
» Réponses : 4
» Affichages : 1,392 -
Problème cache cloudflare...
Forum : Hébergement et référencement
Dernier message : Michel
26/06/2024, 10:35:20
» Réponses : 0
» Affichages : 432 -
Evolution de Smarty/CMSms
Forum : Général
Dernier message : jce76350
07/06/2024, 22:50:18
» Réponses : 24
» Affichages : 14,783 -
Appel à de nouveaux dével...
Forum : Général
Dernier message : jce76350
07/06/2024, 11:36:29
» Réponses : 12
» Affichages : 9,988 -
La Version 2.2.20 est sor...
Forum : Général
Dernier message : jce76350
25/05/2024, 16:26:19
» Réponses : 76
» Affichages : 21,792
- Messages du forum :29,176
- Sujets du forum :4,318
- Membres :670
- Dernier membre :ivis2
Bonjour,
J'ai développé une application qui fonctionne très bien en local (avec cmsms V2.1.4).
Après l'avoir mis en ligne (chez o2switch), l'appli ne fonctionne pas.
URL de l'appli : https://gipel2024.izte.fr
J'ai inséré la ligne
ini_set('display_errors', 1);
L'erreur affichée est :
Deprecated: Optional parameter $level declared before required parameter $message is implicitly treated as a required parameter in /home/qogi5174/gipel2024/system/core/Common.php on line 349
A PHP Error was encountered
Severity: Notice
Message: Only variable references should be returned by reference
Filename: core/Common.php
Line Number: 257
Fatal error: Uncaught Error: Call to undefined function mysql_pconnect() in /home/qogi5174/gipel2024/system/database/drivers/mysql/mysql_driver.php:91 Stack trace: #0 /home/qogi5174/gipel2024/system/database/DB_driver.php(115): CI_DB_mysql_driver->db_pconnect() #1 /home/qogi5174/gipel2024/system/database/DB.php(148): CI_DB_driver->initialize() #2 /home/qogi5174/gipel2024/system/core/Loader.php(346): DB(Array, NULL) #3 /home/qogi5174/gipel2024/system/core/Loader.php(1171): CI_Loader->database() #4 /home/qogi5174/gipel2024/system/core/Loader.php(152): CI_Loader->_ci_autoloader() #5 /home/qogi5174/gipel2024/system/core/Controller.php(51): CI_Loader->initialize() #6 /home/qogi5174/gipel2024/application/controllers/home.php(7): CI_Controller->__construct() #7 /home/qogi5174/gipel2024/system/core/CodeIgniter.php(308): Home->__construct() #8 /home/qogi5174/gipel2024/index.php(92): require_once('/home/qogi5174/...') #9 {main} thrown in /home/qogi5174/gipel2024/system/database/drivers/mysql/mysql_driver.php on line 91
Merci d'avoir lu ce message, et merci de m'aider à résoudre ces erreurs.
Bonne journée
Christian
----------------------------------------------
Config Information:
- php_memory_limit:
- max_upload_size: 2000000
- url_rewriting: mod_rewrite
- page_extension: .html
- query_var: page
- auto_alias_content: true
- locale:
- set_names: true
- timezone: Europe/Paris
- permissive_smarty: false
Php Information:
- phpversion: 8.1.29
- md5_function: On (Vrai)
- json_function: On (Vrai)
- gd_version: 2
- tempnam_function: On (Vrai)
- magic_quotes_runtime: Off (Faux)
- E_ALL: 32767
- E_STRICT: 2048
- E_DEPRECATED: 8192
- test_file_timedifference: Aucune différence de date du système trouvée
- test_db_timedifference: Aucune différence de date du système trouvée
- create_dir_and_file: 1
- memory_limit: 128M
- max_execution_time: 120
- register_globals: Off (Faux)
- output_buffering: 4096
- disable_functions:
- open_basedir:
- test_remote_url: Valable
- file_uploads: On (Vrai)
- post_max_size: 8M
- upload_max_filesize: 2M
- session_save_path: c:/wamp64/tmp (0777)
- session_use_cookies: On (Vrai)
- xml_function: On (Vrai)
- xmlreader_class: On (Vrai)
- check_ini_set: Off (Faux)
- curl: Off
Performance Information:
- allow_browser_cache: On (Vrai)
- browser_cache_expiry: 6000
- php_opcache: On (Vrai)
- smarty_cache: Off (Faux)
- smarty_compilecheck: Off (Faux)
- auto_clear_cache_age: On (Vrai)
- Server Software: Apache/2.4.41 (Win64) PHP/8.1.29 mod_fcgid/2.3.10-dev
- Server Api: apache2handler
- Server Os: WINNT 10.0 On AMD64
- Server Db Type: MySQL (mysqli)
- Server Db Version: 10.4.10
- Server Db Grants: Trouvé un privilège "GRANT ALL" qui semble être adapté
Permission Information:
- tmp: C:\wamp64\www\cmsmadesimple\tmp (0777)
- tmp_cache: C:\wamp64\www\cmsmadesimple\tmp\cache (0777)
- templates_c: C:\wamp64\www\cmsmadesimple\tmp\templates_c (0777)
- modules: C:\wamp64\www\cmsmadesimple\modules (0777)
- uploads: C:\wamp64\www\cmsmadesimple\uploads (0777)
- Masque de création de fichier (umask) : C:\wamp64\www\cmsmadesimple\tmp\cache (0777)
- config_file: 0666
Bonjour,
Lors de l'installation d'une nouvelle 2.2.21 sous wamp 3.3.6 64 bits et win10 j'ai eu le message suivant dés le démarrage du fichier d'installation
Fatal Error
Unable to load template 'file:error.tpl'
#0 /lib/Smarty/sysplugins/smarty_internal_templatebase.php(238): Smarty_Internal_Template->render(false, 1)
#1 /lib/Smarty/sysplugins/smarty_internal_templatebase.php(134): Smarty_Internal_TemplateBase->_execute(Object(Smarty_Internal_Template), NULL, NULL, NULL, 1)
#2 /app/class.cms_install.php(428): Smarty_Internal_TemplateBase->display('error.tpl')<br>#3 /index.php(54): cms_autoinstaller\cms_install->run()
#4 [internal function]: unknown()
#5 C:\wamp64\www\demo\cmsms-2.2.21-install.php(8): Phar::webPhar(NULL, 'index.php')<br>#6 {main}
J'ai exactement le même message lorsque je tente de mettre à jour une version 2.2.19 déjà installée.
merci pour votre aide
Un peu de nouvelles ....
- le dossier /trunk/phar_installer a été supprimé par jdearaujo le 20/06/2024
C'est nouveau ou c'est la fin de l’installateur ?
- Il y a eu quelques corrections (4)
Salut à tous,
j'ai un problème actuellement sur un site hébergé chez Ovh (offre Pro). Le domaine du client pointe vers Cloudflare, qui renvoie vers Ovh ensuite.
On a remarqué de fréquentes erreurs 520 (avec beau petit dessin indiquant un problème entre ovh et cloudflare), surtout lorsque je me connecter à l'admin, mais aussi en visitant le site. Si je modifie ou upload par exemple une image qui porte le même nom que précédemment, l'image n'est pas actualisée, comme si le cache (Cloudfare ?) n'était pas remis à jour.
Je suis obligé de modifier le nom du fichier pour que la mise à jour soit prise en compte immédiatement. Si je modifie du texte dans une page par contre, les mises à jour fonctionnent de suite.
Est-ce que qq'un a remarqué ce problème et l'a corrigé ?
Merci pour votre aide !
Michel
Pour le moment le titre est 2.2.20.x
-> Ha non ça va passer en 2.2.21 à 08/05/24 21h+
Mais cela pourrais être 2.2.20.1 ou 2.2.21 car il y a des bugs qui se corrigent déjà ... c'est le début.
- Révision 13174 -- fixes a typo /lib/classes/contenttypes/ErrorPage.inc.php
->Voir sur le Forum EN avec une Réponse surprenante : "For the Deprecated warnings, ...", un connaisseur
- Révision 13175 -- fixes a notice; a few tweaks for consistency (3 correction)
En fait "ça ressemble bien à la sortie de le 2.2.17", cette 2.2.20.
Salut,
Lorsque l'on accède au profil d'un membre cette erreur s'affiche suivie de quelques bricoles.
Warning [2] Undefined array key 1 - Line: 3602 - File: inc/functions.php PHP 8.2.18 (Linux)
Bonjour à tous,
Je vous présente un site web que j'ai conçu pour une galerie d'art, le premier que je réalise. Avant de me lancer dans ce projet, je n'avais aucune connaissance en HTML ! Il a fallu un certain temps avant son lancement, mais le site est maintenant opérationnel depuis quelques mois. Étant donné le thème artistique, j'ai opté pour un design très épuré afin de maintenir une neutralité visuelle.
Je serais ravi d'obtenir vos avis sur ce travail. J'espère également que la licence du CMSMS est correctement appliquée et qu'il n'y a pas d'erreurs majeures de programmation.
Vous pouvez le consulter à l'adresse suivante : dom-art.fr
À bientôt !
Max
Chat gpt spam, faits ou fiction
Déterminer si un projet est actif et bien entretenu est crucial, surtout lorsqu'on envisage de l'utiliser pour construire un site web ou une application. Voici quelques moyens efficaces d'évaluer le niveau d'activité d'un projet et d'identifier d'éventuels signaux d'alerte :
1. **Site Web du Projet** : Visitez le site web officiel du projet. Recherchez les mises à jour récentes, les actualités ou les publications de blog. Un projet actif maintient généralement un site web à jour avec des annonces sur les nouvelles versions, les fonctionnalités ou les événements de la communauté.
2. **Dépôt GitHub** : Si le projet est open source et hébergé sur GitHub ou une plateforme similaire, vérifiez l'activité du dépôt. Recherchez les commits récents, les pull requests et les problèmes. Un projet sain a généralement des contributions régulières et une activité de développement continue.
3. **Historique des Versions** : Examinez l'historique des versions du projet pour voir quand la dernière version a été publiée et à quelle fréquence de nouvelles versions sont publiées. Des sorties régulières avec des correctifs de bogues, des améliorations de fonctionnalités et des correctifs de sécurité indiquent une maintenance active.
4. **Engagement Communautaire** : Évaluez le niveau d'engagement de la communauté autour du projet. Consultez les forums, les listes de diffusion ou les canaux de médias sociaux pour les discussions, les questions et les réponses des développeurs et des utilisateurs. Les projets actifs ont généralement des communautés vibrantes et solidaires.
5. **Documentation** : Évaluez la qualité et la fraîcheur de la documentation du projet. Les projets actifs maintiennent une documentation complète qui est régulièrement mise à jour pour refléter les changements dans le logiciel.
6. **Suivi des Problèmes** : Examinez le suivi des problèmes du projet pour voir comment les bogues et les demandes de fonctionnalités sont activement traités. Un projet actif a généralement une équipe réactive qui trie et résout les problèmes de manière opportune.
7. **Contributeurs** : Regardez le nombre de contributeurs impliqués dans le projet et leurs niveaux d'activité. Une base de contributeurs diversifiée et active indique un écosystème de projet sain et durable.
8. **Feuille de Route** : Vérifiez si le projet a une feuille de route publique décrivant les fonctionnalités à venir et les plans de développement. Une feuille de route bien définie démontre la direction du projet et l'engagement envers le développement continu.
Signaux d'Alerte à Surveiller :
1. **Dépôt Inactif** : Un manque de commits ou de mises à jour récentes dans le dépôt du projet peut indiquer que le projet n'est plus activement maintenu.
2. **Problèmes Non Résolus** : Si le suivi des problèmes du projet est rempli de bogues non résolus et de demandes de fonctionnalités, cela suggère que les efforts de développement peuvent être au point mort.
3. **Communauté Inactive** : Un manque d'engagement communautaire ou de réponses aux questions des utilisateurs peut être le signe d'un projet en déclin.
4. **Documentation Obsolète** : Si la documentation du projet est obsolète ou incomplète, cela peut indiquer une négligence ou un manque d'attention à la maintenance du projet.
5. **Aucune Publication** : Un long intervalle entre les publications ou un manque de publications récentes peut suggérer que le projet n'est pas activement développé ou maintenu.
6. **Fonctionnalités Abandonnées** : Des fonctionnalités promises mais jamais livrées, ou des plans qui échouent à se concrétiser à plusieurs reprises, peuvent indiquer un manque d'engagement envers le développement du projet.
En évaluant soigneusement ces facteurs et en restant vigilant quant aux signaux d'alerte, vous pouvez prendre des décisions éclairées sur la viabilité d'un projet et s'il convient à vos besoins.
Je suis actuellement en train de réécrire un ancien projet PHP vers PHP 8.3.x, je partage ici mon ensemble d'outils :
# Normes de codage :
Trouver une norme de codage uniforme et basée sur les meilleures pratiques n’est pas si difficile, mettre en œuvre un style uniforme est une autre histoire.
[PHP CodeSniffer](https://github.com/squizlabs/PHP_CodeSniffer), pour définir et appliquer des normes de codage spécifiques,
comme [PSR-12 : Style de codage étendu](https://www.php-fig.org/psr/psr-12/) et/ou [Doctrine Coding Standard](https://www.doctrine-project.org /projects/doctrine-coding-standard/en/11.0/reference/index.html)
# Analyse du codage :
Pour rechercher des erreurs dans les applications PHP -> [Psalm](https://psalm.dev/), [PHPStan](https://phpstan.org/) ou [PHP Mess Detector](https://phpmd.org /).
Pour trouver les problèmes de compatibilité entre versions PHP 5.x, 7.x, 8.x -> [PHPCompatibility](https://github.com/PHPCompatibility/PHPCompatibility)
# Refactorisation automatisée :
Pour résoudre les problèmes de normes de codage -> [PHP Coding Standards Fixer](https://github.com/PHP-CS-Fixer/PHP-CS-Fixer)
Pour obtenir une mise à niveau instantanée ou une refactorine automatisée -> [GetRector](https://getrector.com/)
Certains outils se chevauchent mais peuvent également se compléter.
Erreur bloquante dans class.usertagoperations.inc.php : j'ai trouvé une solution.
En décembre 2023, j'ai eu l'erreur suivante qui m'a bloqué CmsMadeSimple définitivement (l'erreur revenait à chaque appel de index.php) :
Parse error: syntax error, unexpected '}' in /..../..../www/cms/lib/classes/class.usertagoperations.inc.php(306) : eval()'d code on line 1399
J'ai dû réinstaller le cms (version 2.2.19) dans un dossier différent.
Mais au bout de quelques jours, le problème est revenu. J'ai bien dû réinstaller une dizaine de fois.
J'ai été tranquille pendant 3 mois, mais c'est reparti.
Je précise que cela se produit lorsque j'essaie d'enregistrer une balise utilisateur (udt) et que ça ne m'était jamais arrivé avant que je mette le php en version development au lieu de production dans www/.ovhconfig
Mais cette fois, j'ai enfin trouvé comment supprimer l'affichage permanent de l'erreur et le blocage.
C'est pourquoi je vous expose ma méthode au cas où vous auriez les mêmes soucis. Il va quand même falloir mettre les mains dans le cambouis (le php)
Mais je me demande toujours pourquoi certaines fois, les udt sont enregistrés même s'il y a une erreur.
L'erreur est donc dans class.usertagoperations.inc.php, à la ligne 306 pour @eval($code)
function CreateTagFunction($name)
298 { print $name.'<br>'; //ajouté
299 $row = $this->_get_from_cache($name);
if( !$row ) return;
$functionname = 'cms_user_tag_'.$name;
if( !function_exists($functionname) ) {
if( startswith($row['code'],'<?php') ) $row['code'] = substr($row['code'],5);
if( endswith($row['code'],'?>') ) $row['code'] = substr($row['code'],0,-2);
$code = 'function '.$functionname.'($params,$smarty) {'.$row['code']."\n}";
306 @eval($code);
}
return $functionname;
}
J'ai longtemps cru, à cause de la ligne 299, que c'était un problème de cache, mais effacer le cache ne réglait rien.
J'ai ajouté print $name à la ligne 298 pour voir quelle balise provoquait le blocage (l'affichage de l'erreur ne le mentionne pas)
En fait, on voit que tous les udt sont vérifiés à chaque appel de index.php, et c'est donc le dernier affiché qui provoque le blocage.
Pour avoir un plus de détails sur l'erreur, et ne pas bloquer le cms, j'ai ajouté un try - catch autour de @eval($code) :
306 try { eval(@$code); }
catch (ParseError $err) {
print "Erreur dans $name : <br>";
print "$err <br>";
return;
}
Il faut catch (ParseError $err) au lieu d'un simple catch(Exception $ex) parce que eval ne transmet pas des exceptions mais des ParseError.
On obtient alors quelque chose du style :
Erreur dans erreur2: (erreur2 est le nom du userplugin)
ParseError: syntax error, unexpected '...' (T_ELLIPSIS) in /..../..../www/cms4/lib/classes/class.usertagoperations.inc.php(306) : eval()'d code:1 (1 est n° de ligne de l'erreur dans le userplugin)
Stack trace: #0 /www/cms4/lib/classes/internal/class.Smarty_CMS.php(82): UserTagOperations->CreateTagFunction('erreur2')
#1 ...
#2 ...
On peut faciliter la lecture en mettant à partir de la ligne 307 :
catch (ParseError $err) {
$p=strpos($err,'code'); $p2=strpos($err,'Stack'); $ligne=substr($err,$p+5,$p2-$p-6);
print "<br>Erreur dans le plugin $name, ligne $ligne : <br>";
$p= strpos($code,'{'); $code= substr($code,$p+1);
$lignes=explode("\n", $code); print $lignes[$ligne-1].'<br>';
print strtok($err,'#').'<br>';
print strtok('#').'<br>';
return;
}
ce qui donne maintenant :
Erreur dans le plugin erreur2, ligne 1 :
print ... (la ligne qui contient l'erreur)
ParseError: syntax error, unexpected '...' (T_ELLIPSIS) in /www/cms4/lib/classes/class.usertagoperations.inc.php(306) : eval()'d code:1 Stack trace:
0 /www/cms4/lib/classes/internal/class.Smarty_CMS.php(82): UserTagOperations->CreateTagFunction('erreur2')
On peut maintenant supprimer le print $name de la ligne 298
On a réussi à sortir de l'erreur sans bloquer le cms, mais il reste encore une erreur dans un autre fichier ; en effet, la fonction utilisant l'udt n'a toujours pas été créée :
Fatal error: Uncaught --> Smarty: Plugin 'erreur' not callable <-- thrown in /..../..../www/cms4/lib/smarty/sysplugins/smarty_internal_method_registerplugin.php on line 50
A la ligne 50 de smarty_internal_method_registerplugin.php, on trouve : throw new SmartyException("Plugin '{$name}' not callable");
qu'on remplace par : print "<br>Le plugin $name est inutilisable : il faut le corriger ou le supprimer<br>";
Le blocage est terminé , plus besoin de réinstaller !!!