Я пытаюсь использовать скрипт node.js. Я пробовал использовать экспресс / синтаксический анализатор файлов cookie и без ... ATM Я работаю в локальном режиме, но я буду использовать его на werbserver.

Во время всех моих попыток я получал какие-либо ошибки, а файл cookie - нет.

Моя последняя попытка (без парсера экспресс / файлов cookie):

const http = require('http');
const fs = require('fs');
const port = 53134;
const url = require('url');
const fetch = require('node-fetch');   
let express = require('express'); 
let app = express();
let cookieParser = require('cookie-parser');
app.use(cookieParser());



http.createServer((req, res) => {
let responseCode = 404;
let content = '404 Error';
const urlObj = url.parse(req.url, true);
let isEclaire = false;

if (urlObj.query.code) {
    const accessCode = urlObj.query.code;
    console.log(`The access code is: ${accessCode}`);
    
    const data = {
        client_id: '805884181811822624',
        client_secret: 'JRSPE0nmRn881Mi9cLC-gMozHKWLQVPT',
        grant_type: 'authorization_code',
        redirect_uri: 'http://localhost:53134',
        code: accessCode,
        scope: 'identify guilds',
    };

    fetch('https://discord.com/api/oauth2/token', {
        method: 'POST',
        body: new URLSearchParams(data),
        headers: {
            'Content-Type': 'application/x-www-form-urlencoded',
        },
    })
        .then(discordRes => discordRes.json())
        .then(info => {
            console.log(info);
            return info;
        })
        .then(info => fetch('https://discord.com/api/users/@me', {
            headers: {
                authorization: `${info.token_type} ${info.access_token}`,
            },
        }))
        .then(userRes => userRes.json().then(userData => {
            console.log(userData);
            fetch(`https://discord.com/api/guilds/799385448824438824/members/${userData.id}`, {
                headers: {
                    authorization: `Bot ODA1ODg0MTgxODExODIyNjI0.YBhYIQ.h4zLzR7ybBC1uvFSb4iZTH-JVhM`,
                },
            })
            .then(guildRes => guildRes.json().then(guildData => {
                console.log(guildData)
                for(let i = 0; i<guildData.roles.length; i++){
                        console.log(guildData.roles[i]);
                     if(guildData.roles[i] = '804827924217593896') isEclaire = true;
                    }
                console.log(isEclaire)
                    if (isEclaire == true) {
                        console.log('condition is true'); 
                        // Write auth cookie WP
                        res.writeHead(200, {'Set-Cookie': 'cookie', 'Content-Type': 'text/plain'});
                        res.writeHead(301, {Location: `http://localhost:53134/?code=${accessCode}`});
                        res.end();
                    } else {
                        console.log('condition is not true');  
                    }// Console will output 'condition not is true'
            }
            ))
        }))
        }

if (urlObj.pathname === '/') {
    responseCode = 200;
    content = fs.readFileSync('./index.html');
}

res.writeHead(responseCode, {
    'content-type': 'text/html;charset=utf-8',
});

res.write(content);
res.end();
})
    .listen(port);

    

Я предпочитаю использовать экспресс-анализатор файлов cookie или нет.

Спасибо за вашу мысль

0
Ivanova 22 Фев 2021 в 00:55

1 ответ

Лучший ответ

Обработчик запросов к серверу всегда вызывает это:

    res.writeHead(responseCode, {
        'content-type': 'text/html;charset=utf-8',
    });

    res.write(content);
    res.end();

А через некоторое время после завершения вызова fetch() он может попытаться установить ваш файл cookie. К тому времени уже слишком-очень поздно, поскольку ответ уже отправлен. Итак, ваш cookie никогда не отправляется. Чтобы исправить это, вам придется реструктурировать свой код так, чтобы, если вы входите в ветвь, в которой вы вызываете fetch(), то вы вообще НЕ выполняете вышеуказанный код, чтобы ответ fetch() обработчик может отправить ответ, который он хочет.


Кроме того, в коде, в котором вы пытаетесь установить файл cookie, вы делаете следующее:

res.writeHead(200, { 'Set-Cookie': 'cookie', 'Content-Type': 'text/plain' });
res.writeHead(301, { Location: `http://localhost:53134/?code=${accessCode}` });
res.end();

В этом нет никакого смысла. Вы можете res.writeHead() один и только один раз (вы можете установить несколько заголовков в одном вызове). И вы получаете один и только один код статуса для запроса, а не два. Выберите одно или другое.

1
jfriend00 22 Фев 2021 в 05:07