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 :

[Dates] [Linux/Windows] heure incorrecte avec date() mktime()


Sujet :

Langage PHP

  1. #1
    Membre averti
    Homme Profil pro
    Inscrit en
    Mai 2004
    Messages
    803
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations forums :
    Inscription : Mai 2004
    Messages : 803
    Points : 356
    Points
    356
    Par défaut [Dates] [Linux/Windows] heure incorrecte avec date() mktime()
    Bonjour,

    Désirant créer une rubrique "enchères" sur un site, je veux, lors de l'enregistrement d'un objet, créer une date de fin d'enchère correspondant au jour d'introduction + 10, tout en gardant une heure de fin d'enchère correspondant à l'heure d'introduction.

    Pour cela, j'utilise un couplage de la fonction date() et de la fonction mktime(). Le problème est que lors de mes tests en local sous Windows (et serveur Apache), tout fonctionne correctement, autant pour la date que pour l'heure, tandis qu'en ligne, sur un serveur Linux (et toujours Apache), la date est correcte mais l'heure est initialisée à 00h00m00s.

    Voici le code d'initialisation de ma variable de date de fin d'enchère :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    $date = date("Y-m-d H:i:s", mktime(date("H"), date("i"), date("s"), date("m"), date("d")+10,  date("Y")));
    Quelq'un pourrait-il m'aider à résoudre ce problème?

    Merci d'avance.

    Christophe

  2. #2
    Membre expérimenté

    Profil pro
    Inscrit en
    Août 2002
    Messages
    1 060
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2002
    Messages : 1 060
    Points : 1 357
    Points
    1 357
    Par défaut
    Bonjour,

    Essaie avec ça :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    	$fin = date('d-m-Y H:i', strtotime('+10 days'));

  3. #3
    Membre averti
    Homme Profil pro
    Inscrit en
    Mai 2004
    Messages
    803
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations forums :
    Inscription : Mai 2004
    Messages : 803
    Points : 356
    Points
    356
    Par défaut
    Merci pour ton aide...

    Ce que tu proposes ne fonctionne malheureusement ni sous Windows, ni sous Linux : la date et l'heure sont toutes deux initialisées à 0.

  4. #4
    Membre expérimenté

    Profil pro
    Inscrit en
    Août 2002
    Messages
    1 060
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2002
    Messages : 1 060
    Points : 1 357
    Points
    1 357
    Par défaut
    Avant de poster, j'ai testé sur windows et linux, et cela fonctionnait correctement.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    <?php
    	$maintenant = date('d-m-Y H:i');
    	echo $maintenant . '<br>';
    	$fin = date('d-m-Y H:i', strtotime('+10 days'));
    	echo $fin . '<br>';
    ?>
    Résultat sur windows :
    02-07-2006 18:57
    12-07-2006 18:57
    Résultat sur linux :
    02-07-2006 18:58
    12-07-2006 18:58

  5. #5
    Membre averti
    Homme Profil pro
    Inscrit en
    Mai 2004
    Messages
    803
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations forums :
    Inscription : Mai 2004
    Messages : 803
    Points : 356
    Points
    356
    Par défaut
    Je ne comprends pas... Ca ne fonctionne quand même pas chez moi...

    Peut-être est-ce dû à l'enregistrement dans ma bdd Mysql.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    $requete="insert into photos (cle, nom, photo, commentaire, enchere, dateFinEnch, utilisateur) values ('', '$nom', '$tabImg[0]', '$commentaire', '$prixDepart', '$fin', '')";
    Le champ dans ma base est de type "datetime".

    L'affichage dans ma page se fait via le code suivant :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
     $requete = "select cle, commentaire, enchere, utilisateur, DATE_FORMAT(dateFinEnch, '%d/%c/%y à %Hh%im%ssec' ) from photos where photo = '$photo'";
    ...
     
     $dateFinEnch = $row[4];
    ...
     
     echo " : " . $enchere . "&nbsp;euros<br>Fin de l'enchère le " . $dateFinEnch . "</font><form name='formEnchere' action='../Transferts/identification.php' method='post'><input type='submit' value='Enchérir'><input type='hidden' name='cookie' value='" . $photo . "'></form></td></tr></table></div>";

  6. #6
    Membre régulier
    Profil pro
    Inscrit en
    Avril 2004
    Messages
    116
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 116
    Points : 112
    Points
    112
    Par défaut
    Salut,

    Le champ dans ma base est de type "datetime".
    Je ne suis pas sur que cela vienne de là, mais j'ai eu des problèmes en faisant de cette façon, depuis, je ne stocke que des timestamps dans des champs de type INT(11) et je peux plus facilement faire des calculs de dates etc..

    Fred

Discussions similaires

  1. Parser une date suivi d'un fuseaux horaire (date+02:00) et conversion en Date.
    Par SpeedOverflow dans le forum Collection et Stream
    Réponses: 1
    Dernier message: 30/06/2013, 13h37
  2. Renseigner un TDateTime avec une date et une heure ?
    Par MaTHieU_ dans le forum Delphi
    Réponses: 2
    Dernier message: 10/07/2006, 01h50
  3. [MySQL] Requete en relation avec l'heure et la date
    Par darkprophet dans le forum Langage SQL
    Réponses: 2
    Dernier message: 09/05/2006, 22h13
  4. requete avec date et heure
    Par robert_trudel dans le forum Access
    Réponses: 2
    Dernier message: 26/04/2006, 00h15
  5. [Dates] pb avec date et mktime
    Par dark_vidor dans le forum Langage
    Réponses: 1
    Dernier message: 08/09/2005, 21h49

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