新標題:計算並更新令牌的剩餘過期時間
P粉463840170
2023-08-26 23:13:42
<p>我需要在React應用程式中每隔一個小時刷新Spotify令牌(Spotify令牌有效期為1小時)。我知道以下方法使用<strong>useEffect</strong>鉤子和<strong>setInteral</strong></p>
<pre class="brush:php;toolbar:false;">useEffect(() => {
const interval = setInterval(() => {
//呼叫API邏輯
}, 3600);
return () => clearInterval(interval);
}, [user])</pre>
<p>但是當應用程式關閉並重新開啟時,它會再次發出新的請求以獲取令牌(即使舊令牌仍然有效)。因此,我正在嘗試根據剩餘到期時間來實現需要呼叫API以獲取新令牌的功能。如何實現這個功能。 </p>
<p>我還創建了一個函數,用於在過去的時間之後計算剩餘到期時間</p>
<pre class="brush:php;toolbar:false;">export const calculateRemainingExpirationTime = expirationTime => {
const currentTime = new Date().getTime();
const newExpirationTime = new Date(expirationTime).getTime()
const remainingTime = newExpirationTime - currentTime
return remainingTime; //以毫秒為單位
};</pre>
<p>因此,當頁面重新載入時,我需要計算剩餘到期時間,然後基於該時間呼叫API,然後每隔1小時呼叫API以取得新代幣。 </p>
<p><strong>我需要實作以下功能</strong></p>
<ol>
<li>當頁面重新載入時,計算剩餘時間並根據剩餘時間呼叫API</li>
<li>每隔1小時呼叫API</li>
</ol><p><br /></p>
你需要將
過期時間
持久化到localStorage
或使用Redux-persist
來儲存