Как использовать сеансы для аутентификации в Node.js [duplicate]

Отличные ответы выше. Я хочу только добавить, что внутри области вашей функции вы можете присвоить значение этой переменной переменной let self = this;, а затем внутри обратного вызова просто обратиться к данным типа self.data.

Ваш код :

function MyConstructor(data, transport) {
    this.data = data;

    let self = this;   //ADD THIS LINE

    transport.on('data', function () {
        alert(self.data);   //USE IT LIKE THIS
    });
}

// Mock transport object
var transport = {
    on: function(event, callback) {
        setTimeout(callback, 1000);
    }
};

// called as
var obj = new MyConstructor('foo', transport);
130
задан Khanetor 1 January 2016 в 18:21
поделиться

4 ответа

Fetch не использует cookie по умолчанию. Чтобы включить cookie, сделайте следующее:

fetch(url, {
  credentials: "same-origin"
}).then(...).catch(...);
206
ответ дан Jeremy 21 August 2018 в 11:41
поделиться
  • 1
    то же самое происхождение больше не работает, включите (см. ответ @ Джерри): developers.google.com/web/updates/2015/03/introduction-to-fetch – jpic 7 December 2016 в 01:59
  • 2
    Как получить доступ к файлам cookie – Mahesh Karthu 30 March 2017 в 14:37
  • 3
    @jpic: «include» работает только для запросов с кросс-началом, но не для запросов с одним и тем же источником. Официальные документы: github.com/github/fetch#sending-cookies – HoldOffHunger 29 November 2017 в 18:26
  • 4
    Я полагаю, что same-origin (который делает все еще работает) означает, что больше заголовков будет соблюдаться (файлы cookie и т. Д.), Но ваш код будет иметь ограниченный доступ к ответу. – Coderer 13 December 2017 в 16:51
  • 5
    @JohnBalvinAriasThx. Как я понял позже, наличие файла cookie httponly означает, что оно не читается document.cookie, но все еще доступно для запросов ajax или fetch. – Martin Bajcar 28 May 2018 в 22:01

Только что решили. Всего два f. дней брутфорса

Для меня секрет заключался в следующем:

  1. Я вызвал POST / api / auth и увидел, что файлы cookie были успешно получены.
  2. Затем, вызвав GET / api / users / с credentials: 'include' и получив 401 unauth, из-за отсутствия файлов cookie с запросом.

KEY должен установить credentials: 'include' для первого / api / auth call.

3
ответ дан user1671599 21 August 2018 в 11:41
поделиться

В дополнение к ответу @ Khanetor для тех, кто работает с запросами на перекрестный поиск: credentials: 'include'

Пример запроса выборки JSON:

fetch(url, {
  method: 'GET',
  credentials: 'include'
})
  .then((response) => response.json())
  .then((json) => {
    console.log('Gotcha');
  }).catch((err) => {
    console.log(err);
});

https : //developer.mozilla.org/en-US/docs/Web/API/Request/credentials

112
ответ дан zurfyx 21 August 2018 в 11:41
поделиться
  • 1
    как вы устанавливаете cookie? – pomo 30 August 2016 в 17:58
  • 2
    Файл cookie устанавливается с сервера. В моем случае я использовал httponly cookies. – Khanetor 18 November 2016 в 15:25
  • 3
    @Khanetor можно установить файлы cookie с помощью document.cookie по javascript, а затем отправить запрос? – ospider 14 June 2017 в 01:36
  • 4
    Я не уверен. Вы можете попробовать, если это сработает. – Khanetor 14 June 2017 в 10:35
  • 5
    @ospider Вы можете отправить его в заголовке. – 10101010 24 November 2017 в 10:17
0
ответ дан doctorlee 1 November 2018 в 05:43
поделиться
Другие вопросы по тегам:

Похожие вопросы: