اذهب إلى المحتوى

السؤال

Recommended Posts

  • 0
نشر

لديك خطأ 401 أي عملية غير مُصرح بها، لأن التوكن لم يتم تخزينه بعد تسجيل الدخول، لذا الطلب إلى /api/todos يُرسل بدون Authorization، كذلك يوجد تحذير الـ key وسببه أن دالة createTask تُعيد الجسم الكامل { newTodo, user } بينما الواجهة تتوقع كائن المهمة فقط، فينتج عنصر بدون _id في المصفوفة.

في ملف page.tsx يجب حفظ التوكن بعد تسجيل الدخول:

      if(res?.message){
        setError(res?.message);
        setLoading(false);
      }else{
        alert("تم تسجيل الدخول بنجاح");
        localStorage.setItem("token", res.token); // هنا
        router.push("/home")
      }

كذلك، تعديل createTask   لإعادة data.newTodo وللتحقق من الأخطاء:

export async function createTask(title:string) {
  const token = localStorage.getItem("token");
  const res = await fetch('http://localhost:3000/api/todos', { 
    method: "POST",  
    headers: {
      "Content-Type": "application/json",
      "Authorization": `Bearer ${token ?? ""}`
    },
    body: JSON.stringify({title}),
  });
  if (!res.ok) {
    const err = await res.json().catch(() => ({}));
    throw new Error(err?.message || "Request failed");
  }
  const data = await res.json();
  return data.newTodo;
}

كذلك يجب تحويل الـ _id إلى نص عند توليد التوكن فحاليًا أنت تمرر كائن، في ملف app\api\auth\login\route.ts:

    const token = generateToken(user._id.toString());

ثم شغل الخادم وتوجه إلى الرابط التالي وسجل الدخول:

http://localhost:3000/

 

انضم إلى النقاش

يمكنك أن تنشر الآن وتسجل لاحقًا. إذا كان لديك حساب، فسجل الدخول الآن لتنشر باسم حسابك.

زائر
أجب على هذا السؤال...

×   لقد أضفت محتوى بخط أو تنسيق مختلف.   Restore formatting

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   جرى استعادة المحتوى السابق..   امسح المحرر

×   You cannot paste images directly. Upload or insert images from URL.

  • إعلانات

  • تابعنا على



×
×
  • أضف...