Я пытаюсь создать музыкальное приложение и, работая над серверной частью приложения (используя экспресс), я сталкиваюсь с этой странной проблемой документов, не сохраняемых в коллекциях монго.
Я сделал сообщениемаршрут, по которому пользователь отправляет данные формы, который содержит mp3-файл песни и название песни (в дальнейшем у нее будет больше данных).
Я использую multer для анализа данных формы из нескольких частей.Я могу сохранить mp3-файл в mongoDB, используя multer-gridfs-storage.Я хочу сохранить информацию о песне, такую как имя, исполнители и т. Д. В другой коллекции, и вот схема для коллекции:
import mongoose from 'mongoose';
const Schema = mongoose.Schema;
const SongsInfo = new Schema({
name: {
type: String,
required: true,
},
});
const Song = mongoose.model('Song', SongsInfo);
export default Song;
файл index.js:
import Grid from 'gridfs-stream';
import GridFsStorage from 'multer-gridfs-storage';
const app = express();
const conn = mongoose.createConnection(mongoURI);
let gfs;
conn.once('open', () => {
console.log('Connected to mongodb');
gfs = Grid(conn.db, mongoose.mongo);
gfs.collection('songFiles');
});
// storage engine
const storage = new GridFsStorage({
url: mongoURI,
file: (req, file) => new Promise((resolve, reject) => {
crypto.randomBytes(16, (err, buf) => {
if (err) {
return reject(err);
}
const filename = buf.toString('hex') +
path.extname(file.originalname);
let fileInfo;
fileInfo = {
filename,
bucketName: 'songFiles',
};
resolve(fileInfo);
});
}),
});
let upload;
middleWare(app);
app.post('/api/uploadSong', async (req, res) => {
upload = multer({ storage }).any();
upload(req, res, async (err) => {
console.log('in');
if (err) {
// console.log(err);
return res.end('Error uploading file.');
}
const { name } = req.body;
// push a Song into songs collection
const songInfo = new Song({
name,
});
const si = await songInfo.save(); // (*)
console.log(songInfo);
res.json({
songInfo: si,
file: req.file,
});
});
});
Вкл.В строке (*) сервер просто зависает до истечения времени ожидания запроса.На консоли не отображаются ошибки.Не знаю что делать: (