ユーザーのリクエストを処理し、内部APIサービスにプロキシするcookieを受信するnodejsアプリケーションを持っています。ノードフェッチを使用してこれにアプローチする方法は?
スーパーエージェントを提供しないでください。
リクエストのヘッダーに設定することで、Cookieを渡すことができるはずです。
const opts = {
headers: {
cookie: 'accessToken=1234abc; userId=1234'
}
};
const result = await fetch(`/some/url`, opts);
async function login() {
return fetch('<some_url>/login', {
'headers': {
'accept': '*/*',
'content-type': 'application/x-www-form-urlencoded; charset=UTF-8',
'cookie': '',,
},
'body': 'username=foo&password=bar',
'method': 'POST',
});
}
(async() => {
const loginResponse = await login();
const loginCookies = parseCookies(loginResponse);
})();
含めることができます:accept-language
、user-agent
、referer
、accept-encoding
など(Chrome DevTools)でサンプルリクエストを確認してください)
何らかの理由で、ノードフェッチリクエストの結果のCookieは新しいリクエストと互換性がありませんが、次のように解析できます。
function parseCookies(response) {
const raw = response.headers.raw()['set-cookie'];
return raw.map((entry) => {
const parts = entry.split(';');
const cookiePart = parts[0];
return cookiePart;
}).join(';');
}
同じヘッダーを使用して、今後のリクエストでCookieを渡します。
return fetch('<some_url>/dashboard', {
'headers': {
'accept': '*/*',
'cookie': parsedCookies,
},
'method': 'GET',
});
簡単にするために、以下のようにglobal.fetchへのCookieを含むミドルウェアを作成できます。
const realFetch = fetch;
function cookieFetch(fetch, cookie) {
return (url, opts) => {
opts = opts || {};
return fetch(url, Object.assign(opts, {
headers: Object.assign(opts.headers || {}, { cookie })
}));
};
}
function middleware(req, res, next) {
const kuki = req.headers.cookie;
global.fetch = kuki ?
cookieFetch(realFetch, kuki) :
realFetch;
next();
}
module.exports = middleware;