Tajuk baharu: Kira dan kemas kini baki masa tamat tempoh token
P粉463840170
2023-08-26 23:13:42
<p>Saya perlu memuat semula token Spotify setiap jam dalam aplikasi React (Token Spotify sah selama 1 jam). Saya tahu kaedah berikut menggunakan <strong>useEffect</strong> dan <strong>setInteral</strong></p>
<pre class="brush:php;toolbar:false;">useEffect(() ==> {
selang const = setInterval(() => {
//Panggil logik API
}, 3600);
return () => clearInterval(selang);
}, [pengguna])</pre>
<p>Tetapi apabila apl ditutup dan dibuka semula, ia membuat permintaan baharu sekali lagi untuk mendapatkan token (walaupun token lama masih sah). Jadi saya cuba melaksanakan fungsi yang memerlukan panggilan API untuk mendapatkan token baharu berdasarkan baki masa tamat tempoh. Bagaimana untuk melaksanakan fungsi ini. </p>
<p>Saya juga mencipta fungsi yang mengira baki masa tamat tempoh selepas masa berlalu</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
kembali bakiMasa; //dalam milisaat
};</pre>
<p>Jadi apabila halaman dimuat semula, saya perlu mengira baki masa tamat tempoh dan kemudian memanggil API berdasarkan masa itu dan kemudian memanggil API setiap 1 jam untuk mendapatkan token baharu. </p>
<p><strong>Saya perlu melaksanakan fungsi berikut</strong></p>
<ol>
<li>Apabila halaman dimuat semula, kira baki masa dan panggil API berdasarkan masa yang tinggal</li>
<li>Memanggil API setiap jam</li>
</ol><p><br /></p>
Anda perlu berjimat
过期时间
持久化到localStorage
或使用Redux-persist