J'ai une fonction myFetch qui est un wrapper autour de fetch pour ajouter un jeton dans l'en-tête
import clientCookies from "js-cookie"; import {cookies} from "next/headers"; const myFetch = async (...args) => { let token if (typeof window === "undefined") { // client side token = clientCookies.get("authToken") } else { // server side serverCookies = cookies() token = serverCookies.get("authToken").value } args[1].headers = {"Authorization": `bearer ${token}`} const res = await fetch(...args) const data = await res.json() return data }
Mais j'obtiens une erreur lors de l'appel de cette fonction côté client
You're importing a component that needs next/headers. That only works in a Server Component but one of its parents is marked with "use client", so it's a Client Component. Learn more: https://nextjs.org/docs/getting-started/react-essentials
Existe-t-il un moyen d'"importer des {cookies} uniquement à partir du côté serveur 'next/headers'"
Vous pouvez importer conditionnellement chaque module en fonction du type actuel de l'objet fenêtre. Si non défini ; importer le module serveur, sinon le module client :