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());
.
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);
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;
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