web-dev-qa-db-fra.com

Erreur fatale: exception non capturée 'Exception' avec le message 'DateTime :: __ construct (): Échec de l'analyse de la chaîne de temps

Je reçois cette erreur 

(!) Erreur fatale: exception non capturée "Exception" avec le message "DateTime :: __ construct (): Échec de l'analyse de la chaîne temporelle (06-28-2014 07:43:58) à la position 0 (0): caractère inattendu" dans/Utilisateurs/matt/Desktop/Likes/Forgot/activate.php on line 17

En essayant de faire cela 

//DB query
$stmt = $con->prepare("SELECT token_created_at from reset WHERE token = :urltoken");
$stmt->bindValue(':urltoken', $_GET['token']);
$stmt->execute();
$stmt->setFetchMode(PDO::FETCH_ASSOC);
while($row = $stmt->fetch()) {
     $token_created_at = $row['token_created_at'];
}

//Remove after testing
echo $token_created_at;

$my_dt = new DateTime($token_created_at);

//Modify error
$expires_at = $my_dt->modify('+1 hour');

//Return current time to match
$current_time = date('m-d-Y H:i:s ', time());

La ligne 17 est $my_dt = new DateTime($token_created_at); et voici mon format horaire 06-28-2014 07:43:58.

Voici comment je génère token_created_at, $time_gen = date('m-d-Y H:i:s ', time());.

9
user3537990

La chaîne de date que vous passez est non prise en charge par l'analyseur DateTime. Vous devez créer un objet DateTime en utilisant createFromFormat . Cette méthode vous permet de spécifier le format personnalisé lors de la création d'un nouvel objet DateTime:

$my_dt = DateTime::createFromFormat('m-d-Y H:i:s', $token_created_at);

Si vous obtenez toujours une erreur, cela signifie que votre $token_created_at n'est pas dans le format que vous avez spécifié:

$now = date('m-d-Y H:i:s'); //string(19) "06-28-2014 15:00:47"

var_dump(DateTime::createFromFormat('m-d-Y H:i:s', $now));
object(DateTime)#1 (3) {
  ["date"]=>
  string(19) "2014-06-28 15:00:47"
  ["timezone_type"]=>
  int(3)
  ["timezone"]=>
  string(13) "Europe/Berlin"
}

Modifier

Je vois votre problème - la chaîne de format a un espace après s. Les chaînes de format doivent correspondre à exactement:

$my_dt = DateTime::createFromFormat('m-d-Y H:i:s ', $token_created_at);
12
Christian P

Mis à jour ma réponse

function date_time( $date ) {
    if( $date == "" ){
        return "";
    } else {
        // echo $date;
        $my_date  = DateTime::createFromFormat( 'm-d-Y H:i:s', $date );
        // echo '<pre>';
        // print_r($my_date);
        // echo '</pre>';
        $new_date = $my_date->format( 'Y-m-d H:i:s' );
        return $new_date;
    }
}

$save = date_time('06-28-2014 07:43:58');
$my_dt = new DateTime( $save );

//Modify error
$expires_at = $my_dt->modify('+1 hour');
$expires_date = $my_dt->format( 'Y-m-d H:i:s' );

echo $expires_date;
//Return current time to match
$current_time = date('m-d-Y H:i:s', time());
echo $current_time;
1
Abhineet Verma

Essaye ça:

$token_created_at = DateTime::createFromFormat("m-d-Y H:i:s", $token_created_at);
$my_dt = new DateTime($token_created_at->format('Y-m-d H:i:s'));
$expires_at = $my_dt->modify('+1 hour');

Cela va générer 

2014-06-28 08:43:58
0
fortune