ПО промежуточного слоя Express не используется

Приведенный ниже код представляет собой промежуточное программное обеспечение, используемое для создания свойства req.user, которое содержит объект пользователя, если req.session.user существует. Однако по какой-то причине он никогда не попадает в промежуточное программное обеспечение. Так что "hihihhiihi" тоже не печатается.

// have middleware that deserializes the logged in user
// if req.session.user exists, then create property req.user that contains the user obj
app.use(async (req, res, next) => {
  console.log('hihihhiihi');
  if(req.session.username) {
    console.log(req.session.username,' is abcdefg');
    req.user = await User.findOne({username: req.session.username}).exec();
  }
  next();
});

Это мой App.js

import bodyParser from 'body-parser';
import mongoose from 'mongoose';
import cors from 'cors';

import diaryRoutes from './routes/diarys.js';
import userRoutes from './controllers/user.js'
const app = express();

// app.use(express.urlencoded({ extended: false }));
app.use(bodyParser.json({ limit: '30mb', extended: true }))
app.use(bodyParser.urlencoded({ limit: '30mb', extended: true }))
app.use(cors());
import session from 'express-session';

// after login, don't have to enter username and pw again
// ...so sessions
const sessionOptions = { 
  secret: 'secret for signing session id', 
  saveUninitialized: false, 
  resave: false 
};

app.use(session(sessionOptions));

app.use((req, res, next) => {
  console.log('session contains', req.session);
  next();
});

// have middleware that deserializes the logged in user
// if req.session.user exists, then create property req.user that contains the user obj
app.use(async (req, res, next) => {
  console.log('hihihhiihi');
  if(req.session.username) {
    console.log(req.session.username,' is abcdefg');
    req.user = await User.findOne({username: req.session.username}).exec();
  }
  next();
});

app.use('/diarys', diaryRoutes);
app.use('/users', userRoutes);

const CONNECTION_URL = 'someurl';
const PORT = process.env.PORT || 5000;

mongoose.connect(CONNECTION_URL, { useNewUrlParser: true, useUnifiedTopology: true })
  .then(() => app.listen(PORT, () => console.log(`Server Running on Port ${PORT}`)))
  .catch((error) => console.log(`Error message(can't connect): ${error}`));

Попробуйте создать IIFE вместо того, чтобы делать функцию асинхронной.

code 23.04.2022 01:02
Формы c голосовым вводом в React с помощью Speechly
Формы c голосовым вводом в React с помощью Speechly
Пытались ли вы когда-нибудь заполнить веб-форму в области электронной коммерции, которая требует много кликов и выбора? Вас попросят заполнить дату,...
В чем разница между Promise и Observable?
В чем разница между Promise и Observable?
Разберитесь в этом вопросе, и вы значительно повысите уровень своей компетенции.
Сравнение структур данных: Массивы и объекты в Javascript
Сравнение структур данных: Массивы и объекты в Javascript
Итак, вы изучили основы JavaScript и хотите перейти к изучению структур данных. Мотивация для изучения/понимания Структур данных может быть разной,...
Создание собственной системы электронной коммерции на базе Keystone.js - настройка среды и базовые модели
Создание собственной системы электронной коммерции на базе Keystone.js - настройка среды и базовые модели
Прошлая статья была первой из цикла статей о создании системы электронной коммерции с использованием Keystone.js, и она была посвящена главным образом...
Приложение для отслеживания бюджета на React js для начинающих
Приложение для отслеживания бюджета на React js для начинающих
Обучение на практике - это проверенная тема для достижения успеха в любой области. Если вы знаете контекст фразы "Практика делает человека...
Стоит ли использовать React в 2022 году?
Стоит ли использовать React в 2022 году?
В 2022 году мы все слышим о трендах фронтенда (React, Vue), но мы не знаем, почему мы должны использовать эти фреймворки, когда их использовать, а...
0
1
26
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Я понял, что использую React во внешнем интерфейсе, а также использую res.json() для отправки ответа во внешний интерфейс, поэтому я должен использовать

app.use(express.json());

вместо

app.use(bodyParser.urlencoded({ limit: '30mb', extended: true }))

Если у кого-то есть похожая проблема, проверьте, используете ли вы res.json или res.render :)

Другие вопросы по теме