Rumah >hujung hadapan web >tutorial js >Bagaimana untuk Mengendalikan Lencongan Selepas Log Masuk dengan API Ambil JavaScript?

Bagaimana untuk Mengendalikan Lencongan Selepas Log Masuk dengan API Ambil JavaScript?

Barbara Streisand
Barbara Streisandasal
2024-10-18 07:23:29713semak imbas

How to Handle Redirects After Login with JavaScript Fetch API?

Bagaimana untuk mengubah hala pengguna ke halaman lain selepas log masuk menggunakan JavaScript Fetch API?

Apabila menggunakan fungsi fetch() untuk melaksanakan permintaan POST ke pelayan yang bertindak balas dengan RedirectResponse, ubah hala akan diikuti secara automatik pada sisi klien. Ini kerana mod ubah hala ditetapkan untuk mengikut secara lalai dalam fungsi fetch(). Akibatnya, pengguna tidak akan diubah hala ke URL baharu, sebaliknya fetch() akan mengikuti ubah hala tersebut di belakang tabir dan mengembalikan respons daripada URL ubah hala.

Untuk mengatasinya, anda boleh menyemak sama ada respons adalah hasil daripada permintaan yang anda buat yang telah diubah hala. Jika ya, anda boleh mendapatkan semula sifat url respons, yang akan mengembalikan URL akhir yang diperoleh **selepas** sebarang ubah hala dan menggunakan window.location.href JavaScript, anda boleh mengubah hala pengguna ke URL sasaran (iaitu, halaman ubah hala). Daripada window.location.href, seseorang juga boleh menggunakan window.location.replace(). Perbezaan daripada menetapkan nilai sifat href ialah apabila menggunakan kaedah location.replace(), selepas menavigasi ke URL yang diberikan, halaman semasa tidak akan disimpan dalam sejarah sesi—bermaksud pengguna tidak akan dapat menggunakan back butang untuk menavigasi ke sana.

Contoh kod:

<code class="javascript">document.getElementById("myForm").addEventListener("submit", function (e) {
  e.preventDefault(); // Cancel the default action
  var formElement = document.getElementById("myForm");
  var data = new FormData(formElement);
  fetch("http://my-server/login", {
    method: "POST",
    redirect: "follow", // Change it to "manual" if you want to handle redirects manually
    body: data,
  })
    .then((res) => {
      if (res.redirected) {
        window.location.href = res.url; // or, location.replace(res.url);
        return;
      } else {
        return res.text();
      }
    })
    .then((data) => {
      document.getElementById("response").innerHTML = data;
    })
    .catch((error) => {
      console.error(error);
    });
});</code>

Nota: Jika anda menggunakan permintaan silang asal, anda akan perlu menetapkan pengepala respons Access-Control-Expose-Headers pada bahagian pelayan untuk memasukkan pengepala Lokasi. Ini kerana hanya pengepala respons yang disenarai selamat CORS didedahkan secara lalai.

Atas ialah kandungan terperinci Bagaimana untuk Mengendalikan Lencongan Selepas Log Masuk dengan API Ambil JavaScript?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn