Nouveau titre : Calculer et mettre à jour le délai d'expiration restant d'un token
P粉463840170
2023-08-26 23:13:42
<p>Je dois actualiser le jeton Spotify toutes les heures dans l'application React (le jeton Spotify est valable 1 heure). Je sais que la méthode suivante utilise le crochet <strong>useEffect</strong>
<pre class="brush:php;toolbar:false;">useEffect(() => {
const intervalle = setInterval(() => {
//Appeler la logique de l'API
}, 3600);
return () => clearInterval(intervalle);
}, [utilisateur])</pre>
<p>Mais lorsque l'application est fermée et rouverte, elle fait à nouveau une nouvelle demande pour obtenir le jeton (même si l'ancien jeton est toujours valide). J'essaie donc d'implémenter une fonctionnalité qui nécessite d'appeler une API pour obtenir un nouveau jeton en fonction du délai d'expiration restant. Comment implémenter cette fonction. </p>
<p>J'ai également créé une fonction qui calcule le délai d'expiration restant après le temps écoulé</p>
<pre class="brush:php;toolbar:false;">export const calculateRemainingExpirationTime = expirationTime =>
const currentTime = new Date().getTime();
const newExpirationTime = new Date(expirationTime).getTime()
const restantTime = newExpirationTime - currentTime
renvoie le temps restant //en millisecondes
};</pré>
<p>Ainsi, lorsque la page se recharge, je dois calculer le délai d'expiration restant, puis appeler l'API en fonction de ce délai, puis appeler l'API toutes les heures pour obtenir un nouveau jeton. </p>
<p><strong>Je dois implémenter les fonctions suivantes</strong></p>
<ol>
<li>Lorsque la page se recharge, calculez le temps restant et appelez l'API en fonction du temps restant</li>
<li>Appel de l'API toutes les heures</li>
</ol><p><br /></p>
Vous devez économiser
过期时间
持久化到localStorage
或使用Redux-persist