IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Langage PHP Discussion :

[CSV] Ecrire dans un fichier CSV sur un serveur [PHP 5.0]


Sujet :

Langage PHP

  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Mars 2009
    Messages
    20
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2009
    Messages : 20
    Points : 10
    Points
    10
    Par défaut [CSV] Ecrire dans un fichier CSV sur un serveur
    Bonjour,


    Je suis actuellement en train de développer une application en flash avec des scripts PHP qui écrive dans des fichiers CSV.

    Mon soucis c'est que je n'arrive pas à écrire dans ces fichiers, une fois l'application en ligne, alors qu'en local ça marche.

    J'ai bien modifier le CHMOD des fichiers mais rien n'y fait, je ne comprend pas.

    Merci d'avance pour votre aide,


    *Math_thefire*

  2. #2
    Membre actif Avatar de JmL40
    Profil pro
    Inscrit en
    Mai 2007
    Messages
    348
    Détails du profil
    Informations personnelles :
    Âge : 38
    Localisation : France

    Informations forums :
    Inscription : Mai 2007
    Messages : 348
    Points : 246
    Points
    246
    Par défaut
    Salut,

    Peux-tu nous en dire un peu plus sur ton problème, si des erreurs sont retournées, ou autres ?

    Merci
    while (true) echo 'comique';
    Du comique de répétition ...
    Pour des questions de lisibilité, utilisez la balise [code]
    Si votre problème est résolu, n'oubliez pas le tag

  3. #3
    Membre à l'essai
    Profil pro
    Inscrit en
    Mars 2009
    Messages
    20
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2009
    Messages : 20
    Points : 10
    Points
    10
    Par défaut
    En fait j'ai un formulaire et si tous les champs sont remplis, je les écrit dans le fichier CSV, or j'ai beau remplir tous les champs ma variables me retourne tous le temps "Tous les champs ne sont pas remplis". (Or ça marche en local !)

    extrait du code :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
     
    if(/*conditions*/) {
    	//renvoyer a Flash une variable au format MIME
    	$resultat="Tous les champs ne sont pas rempli";
    	$resultat = utf8_encode($resultat);
    	echo "&resultat=".$resultat;
    	exit();
    }
    else{
    	// écrire ces variables dans un fichier CSV
    	$fichier = fopen("CSV/$valClient.csv","a+");
    	$variable = str_replace(",", ".", $variable);
    	$commande = array($variable . ";" .
    				$variable2 . ";" .
    				$variable3 . ";" .
    				$variable4 . ";" .
    				$variable5. ";");
    	foreach ($commande as $line) {
    		fputcsv($fichier, split(";", $line));
    	}
    }
    fclose($fichier);

    De plus j'ai l'impression que lorsque je change le CHMOD de mon fichiers, ça ne fonctionne pas !

    En vous remerciant par avance,


    *Math_thefire*

  4. #4
    Membre éclairé
    Avatar de djayp
    Profil pro
    Inscrit en
    Avril 2004
    Messages
    295
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 295
    Points : 687
    Points
    687
    Par défaut
    Salut,

    visiblement les conditions de ton if ne sont pas remplies :

    Peux tu nous indiquer quelles sont-elles ???

    A+

  5. #5
    Membre à l'essai
    Profil pro
    Inscrit en
    Mars 2009
    Messages
    20
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2009
    Messages : 20
    Points : 10
    Points
    10
    Par défaut
    Voici le code avec plus d'information, je pensais qu'en le simplifiant ça suffirait :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
     
    // on récupère les variables de Flash
    $valArticle = strip_tags(utf8_decode($_POST['article']));
    $valQuantite = strip_tags(utf8_decode($_POST['quantite']));
    $valType = strip_tags(utf8_decode($_POST['type']));
    $valDelais = strip_tags(utf8_decode($_POST['delais']));
    $valPrix = strip_tags(utf8_decode($_POST['prix']));
     
     
    if(($valArticle == "undefined") || ($valArticle == "Article")
    	|| ($valArticle == "#") || ($valQuantite == "undefined")
    	|| ($valQuantite == "") || ($valType == "undefined")
    	|| ($valType == "Type") || ($valType == "#")
    	|| ($valDelais == "undefined") || ($valDelais == "Delais")
    	|| ($valDelais == "#")){
    	//renvoyer a Flash une variable au format MIME
    	$resultat="Tous les champs ne sont pas rempli";
    	$resultat = utf8_encode($resultat);
    	echo "&resultat=".$resultat;
    	exit();
    }
    else{
    	// écrire ces variables dans un fichier CSV
    	$fichier = fopen("CSV/$valClient.csv","a+");
    	$valPrix = str_replace(",", ".", $valPrix);
    	$valPrix = $valPrix * $valQuantite;
    	$valPrix = str_replace(",", ".", $variable);
    	$commande = array($valArticle . ";" .
    				$valQuantite . ";" .
    				$valPrix . ";" .
    				$valType . ";" .
    				$valDelais . ";");
    	foreach ($commande as $line) {
    		fputcsv($fichier, split(";", $line));
    	}
    }
    fclose($fichier);
    Je ne pense pas que l'erreur vienne du code, mais plutôt du fichier, qui lorsque je lui met un CHMOD de 777, me dit que c'est bon puis quand je retourne voir les proprièté il est revenue à 644 (lecture et écriture pour le priétaire et uniquement lecture pour les autres), or le PHP à besoins d'un CHMOD à 777 pour écrire dans un fichier.

    Je ne sais pas comment faire,


    *Math_thefire*

  6. #6
    Membre éclairé
    Avatar de djayp
    Profil pro
    Inscrit en
    Avril 2004
    Messages
    295
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 295
    Points : 687
    Points
    687
    Par défaut
    Vu que ce que tu décris :
    Citation Envoyé par math_thefire Voir le message
    En fait j'ai un formulaire et si tous les champs sont remplis, je les écrit dans le fichier CSV, or j'ai beau remplir tous les champs ma variables me retourne tous le temps "Tous les champs ne sont pas remplis". (Or ça marche en local !)
    le problème vient surement du if , mais tes conditions me semblent correctes. As-tu ce message en permanence ? Que ce passe t'il se tu mets en commentaires ce if { } ?

    Pour les CHMOD, essaie de les appliquer à la fois à ton répertoire /CSV/ mais aussi à ton fichier.

    Sinon, tu peux regarder s'il n'y a pas un problème de chemin à savoir :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    // $chemin = "C:/monsite/"; // chemin en local
    $chemin = "/home/www/monsite/"; // chemin distant, utiliser phpinfo() pour la valeur exacte
    $fichier = fopen($chemin."CSV/".$valClient.".csv","a+");
    Voilà quelques pistes à explorer...
    A+

  7. #7
    Membre à l'essai
    Profil pro
    Inscrit en
    Mars 2009
    Messages
    20
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2009
    Messages : 20
    Points : 10
    Points
    10
    Par défaut
    J'ai réussi à mettre le fichier en CHMOD 777 en changeant de serveur, en fait certain serveur ne l'accepte pas (comme free par exemple).

    J'ai aussi réussi à passer les conditions, je n'est plus "Tous les champs ne sont pas remplis" mais "La commande à bien été effectuée".

    Voilà, ce que j'ai rajouté :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
     
    // on récupère les variables de Flash
    $valArticle = strip_tags(utf8_decode($_POST['article']));
    $valQuantite = strip_tags(utf8_decode($_POST['quantite']));
    $valType = strip_tags(utf8_decode($_POST['type']));
    $valDelais = strip_tags(utf8_decode($_POST['delais']));
    $valPrix = strip_tags(utf8_decode($_POST['prix']));
     
     
    if(($valArticle == "undefined") || ($valArticle == "Article")
    	|| ($valArticle == "#") || ($valQuantite == "undefined")
    	|| ($valQuantite == "") || ($valType == "undefined")
    	|| ($valType == "Type") || ($valType == "#")
    	|| ($valDelais == "undefined") || ($valDelais == "Delais")
    	|| ($valDelais == "#")){
    	//renvoyer a Flash une variable au format MIME
    	$resultat="Tous les champs ne sont pas rempli";
    	$resultat = utf8_encode($resultat);
    	echo "&resultat=".$resultat;
    	exit();
    }
    else{
    	// edit : vérifie si le fichier est en CHMOD 777
    	if(chmod("/CSV/$valClient.csv",0777) == true){
    		// écrire ces variables dans un fichier CSV
    		$fichier = fopen("/CSV/$valClient.csv","a+");
    		$valPrix = str_replace(",", ".", $valPrix);
    		$valPrix = $valPrix * $valQuantite;
    		$valPrix = str_replace(",", ".", $variable);
    		$commande = array($valArticle . ";" .
    					$valQuantite . ";" .
    					$valPrix . ";" .
    					$valType . ";" .
    					$valDelais . ";");
    		foreach ($commande as $line) {
    			fputcsv($fichier, split(";", $line));
    		}
    	}
    	fclose($fichier);
     
    	//edit : renvoyer a Flash une variable au format MIME
    	$resultat = "La commande à bien été effectuée";
    	$resultat = utf8_encode($resultat);
    	echo "&resultat=".$resultat;
    	exit();
    }
    Par contre je n'arrive toujours pas à écrire dans le fichier.
    J'ai bien essayé de changer le chemin, mais je ne comprend pas comment fonctionne la fonction phpinfo() pourrait tu m'expliquer ?

    Si j'enlève les conditions, ma variable de retour me retourne "undefined".

    Merci de ton aide,


    *Math_thefire*

  8. #8
    Membre éclairé
    Avatar de djayp
    Profil pro
    Inscrit en
    Avril 2004
    Messages
    295
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 295
    Points : 687
    Points
    687
    Par défaut
    Salut,

    Tu trouveras des détails sur phpinfo dans la FAQ. C'est une fonction php qui te permet d'afficher pleins d'information sur ton serveur.

    Il te faut récupérer la valeur de DOCUMENT_ROOT, qui correspond à la "racine" de ton site web.

    Sans passer par phpinfo, tu peux aussi, utiliser la variable $_SERVER['DOCUMENT_ROOT'];

    A++

  9. #9
    Membre à l'essai
    Profil pro
    Inscrit en
    Mars 2009
    Messages
    20
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2009
    Messages : 20
    Points : 10
    Points
    10
    Par défaut
    Merci, j'ai fait un test mais ça ne change rien !

    J'ai essayé d'effectuer la manipulation en dehors de l'application :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
     
    <?php
    	$valClient = "test";
    	$valArticle = "test2";
    	$valDateCommande = "test3";
    	$chemin = $_SERVER['DOCUMENT_ROOT'];
    	$fichier = fopen($chemin."test.csv","a+");
    	$commande = array($valClient . ";" .
    				$valArticle . ";" .
    				$valDateCommande);
     
    	foreach ($commande as $line) {
    		fputcsv($fichier, split(";", $line));
    	}
    	fclose($fichier);
    ?>
    et ça me retourne :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    Warning: fopen(/*chemin*//test.csv): failed to open stream: Permission denied in test.php on line 6
     
    Fatal error: Call to undefined function: fputcsv() in test.php on line 12
    A parement une erreur de permission non accorder, y a t il une manipulation à effectuer sur le serveur pour remédier à ce problème ?

    Marci d'avance,


    *Math_thefire*

  10. #10
    Membre à l'essai
    Profil pro
    Inscrit en
    Mars 2009
    Messages
    20
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2009
    Messages : 20
    Points : 10
    Points
    10
    Par défaut
    Pour la première erreur, c'est bon, c'est mon chemin qui n'était pas correct.

    Mais pour la seconde, je ne comprend pas, il ne reconnait pas la fonction ?

    Avez vous une idée ?

    Merci d'avance,


    *Math_thefire*

  11. #11
    Membre éclairé
    Avatar de djayp
    Profil pro
    Inscrit en
    Avril 2004
    Messages
    295
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 295
    Points : 687
    Points
    687
    Par défaut
    Salut,

    La fonction fputcsv n'est disponible qu'avec les versions php >=5.1.0.
    Es-tu sur que ton serveur dispose d'une version récente de php (vérifie avec phpinfo() ) ?
    Si oui, peut-être que ton hébergeur a désactivé cette fonction...


    A++

  12. #12
    Membre à l'essai
    Profil pro
    Inscrit en
    Mars 2009
    Messages
    20
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2009
    Messages : 20
    Points : 10
    Points
    10
    Par défaut
    Effectivement, il s'agit de "PHP Version 4.4.0", je ne sais pas pourquoi, j'étais persuader qu'il s'agissait de la version 5.

    J'ai donc utiliser la fonction fputs() à la place de fputcsv, voici le code aprés modification :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
     
    // on récupère les variables de Flash
    $valArticle = strip_tags(utf8_decode($_POST['article']));
    $valQuantite = strip_tags(utf8_decode($_POST['quantite']));
    $valType = strip_tags(utf8_decode($_POST['type']));
    $valDelais = strip_tags(utf8_decode($_POST['delais']));
    $valPrix = strip_tags(utf8_decode($_POST['prix']));
     
     
    if(($valArticle == "undefined") || ($valArticle == "Article")
    	|| ($valArticle == "#") || ($valQuantite == "undefined")
    	|| ($valQuantite == "") || ($valType == "undefined")
    	|| ($valType == "Type") || ($valType == "#")
    	|| ($valDelais == "undefined") || ($valDelais == "Delais")
    	|| ($valDelais == "#")){
    	//renvoyer a Flash une variable au format MIME
    	$resultat="Tous les champs ne sont pas rempli";
    	$resultat = utf8_encode($resultat);
    	echo "&resultat=".$resultat;
    	exit();
    }
    else{
    	// écrire ces variables dans un fichier CSV
    	$fichier = fopen("/CSV/$valClient.csv","a+");
    	$valPrix = str_replace(",", ".", $valPrix);
    	$valPrix = $valPrix * $valQuantite;
    	$commande = "\n" . $valArticle . ";" .
    				$valQuantite . ";" .
    				$valPrix . ";" .
    				$valType . ";" .
    				$valDelais;
    	fputs($fichier, $commande);
    	fclose($fichier);
     
    	//renvoyer a Flash une variable au format MIME
    	$resultat = "La commande à bien été effectuée";
    	$resultat = utf8_encode($resultat);
    	echo "&resultat=".$resultat;
    	exit();
    }
    Et ça marche !


    *Math_thefire*

  13. #13
    Membre éclairé
    Avatar de djayp
    Profil pro
    Inscrit en
    Avril 2004
    Messages
    295
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 295
    Points : 687
    Points
    687
    Par défaut
    Cool !

  14. #14
    Membre à l'essai
    Profil pro
    Inscrit en
    Mars 2009
    Messages
    20
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2009
    Messages : 20
    Points : 10
    Points
    10
    Par défaut

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. [Lazarus] Ecrire dans un fichier texte sur un serveur distant
    Par fredcop dans le forum Lazarus
    Réponses: 4
    Dernier message: 18/03/2013, 10h38
  2. Ecrire dans u fichier .csv
    Par Jiyuu dans le forum Général Python
    Réponses: 2
    Dernier message: 21/04/2008, 07h57
  3. Réponses: 8
    Dernier message: 08/12/2007, 15h21
  4. ecrire dans un fichier csv ou ods (xls)
    Par afrodje dans le forum VB.NET
    Réponses: 2
    Dernier message: 03/04/2007, 16h45
  5. Ecrire dans un fichier .csv ou .txt à partir d'excel
    Par Beamish dans le forum Macros et VBA Excel
    Réponses: 22
    Dernier message: 02/03/2007, 12h16

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo