【发布时间】:2017-10-19 15:18:46
【问题描述】:
我正在为我正在开发的应用程序做一个非常基本的服务器,以帮助我理解 node js 和 mongodb 作为我的移动应用程序的服务器。我遵循了一个教程,并让它发布了简单的待办事项。但是我接下来要做的是将图像与 POST 请求中的文本一起发布,并使用 GET 请求作为 JSON 检索它们。下面是我迄今为止成功将待办事项名称连同创建日期一起发布到数据库的代码。
下面的类是我为 Schema 所拥有的,但我试图添加我认为添加图像的方式,但我认为这是不正确的。我相信正确的做法是将图像存储在文件系统中,例如https://{mydomain}/images/,然后在发布图像数据时,将图像存储在文件夹中,并将图像的 url 存储在数据库中?
todoListModel.js
'use strict';
var mongoose = require('mongoose');
var Schema = mongoose.Schema;
var TaskSchema = new Schema({
name: {
type: String,
required: 'Kindly enter the name of the task'
},
img: {
data: Buffer,
contentType: String
},
Created_date: {
type: Date,
default: Date.now
}
});
module.exports = mongoose.model('Tasks', TaskSchema);
todoListController.js
'use strict';
var mongoose = require('mongoose'),
Task = mongoose.model('Tasks');
exports.list_all_tasks = function(req, res) {
Task.find({}, function(err, task) {
if (err)
res.send(err);
res.json({
data: {
task
}
});
});
};
exports.create_a_task = function(req, res) {
var new_task = new Task(req.body);
new_task.save(function(err, task) {
if (err)
res.send(err);
res.json({
data: {
task
}
});
});
};
exports.read_a_task = function(req, res) {
Task.findById(req.params.taskId, function(err, task) {
if (err)
res.send(err);
res.json({
data: {
task
}
});
});
};
exports.update_a_task = function(req, res) {
Task.findOneAndUpdate({_id: req.params.taskId}, req.body, {new: true}, function(err, task) {
if (err)
res.send(err);
res.json({
data: {
task
}
});
});
};
exports.delete_a_task = function(req, res) {
Task.remove({
_id: req.params.taskId
}, function(err, task) {
if (err)
res.send(err);
res.json({ message: 'Task successfully deleted' });
});
};
todoListRoutes.js
'use strict';
module.exports = function(app) {
var todoList = require('../controllers/todoListController');
// todoList Routes
app.route('/tasks')
.get(todoList.list_all_tasks)
.post(todoList.create_a_task);
app.route('/tasks/:taskId')
.get(todoList.read_a_task)
.put(todoList.update_a_task)
.delete(todoList.delete_a_task);
};
server.js
var express = require('express'),
app = express(),
port = process.env.PORT || 3000,
mongoose = require('mongoose'),
Task = require('./api/models/todoListModel'), //created model loading here
bodyParser = require('body-parser');
// mongoose instance connection url connection
mongoose.Promise = global.Promise;
mongoose.connect('mongodb://localhost/Tododb');
app.use(bodyParser.urlencoded({ extended: true }));
app.use(bodyParser.json());
var routes = require('./api/routes/todoListRoutes'); //importing route
routes(app); //register the route
app.listen(port);
console.log('todo list RESTful API server started on: ' + port);
如果有人能对此有所了解,将不胜感激。
【问题讨论】:
标签: javascript ios node.js mongodb