簡體   English   中英

Node JS&MongoDB-發布和獲取iOS服務器API的圖像

[英]Node JS & MongoDB - Post and Get images for iOS server api

我正在為一個正在使用的應用程序做一個非常基本的服務器,以幫助我理解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);

如果有人可以對此有所了解,將不勝感激。

我認為這是最好的方法,首先將圖像上傳到項目文件夾中,或者如果正在使用,則可以將圖像上傳到AWS S3存儲桶中,然后將該圖像的路徑存儲到集合中。 正確的架構是

var TaskSchema = new Schema({
 name: {
  type: String,
  required: 'Kindly enter the name of the task'
 },
 img: {
  type: String,
 },
 Created_date: {
  type: Date,
  default: Date.now
 }
});

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM