2017-04-13 5 views
0

axiosからnode.jsに2つのID(book_id、user_id)を渡そうとしています。 私がconsole.log(req.body)を実行すると、空のオブジェクトが返されます。axactからnode.jsを呼び出すと、req.bodyに空の{}が与えられます

console.log( "bookid"、book_id、 "user"、user_id)をaxiosから取得した場合。 それを返します:

enter image description here

私は

app.delete('/mypage', function(req, res, next) { 
    console.log("req.body", req.body) 
    db.delete_mylist([req.body.book_id], function(err, individual) { 


     if(err) res.status(500).send(err); 
     else { 
      db.get_mypage_book(function(err, all) { 
       if(err) res.status(500).send(err); 
       else res.send(all); 
      }); 
     } 
    }); 
}); 

をCONSOLE.LOGするとそれは私がここで間違ってやっているものを私にこの

enter image description here

わからないを提供します。それはapp.postで動作しましたが、app.delete上に何も与えていないようです。

axiosは、それがで禁じられていないもののdeletehttps://github.com/mzabriskie/axios#request-method-aliases

で体内のデータの送信をサポートようにそれは見えないのNode.js

const express = require('express'); 
const bodyParser = require('body-parser'); 
const session = require('express-session'); 
const cors = require('cors'); 
const massive = require('massive'); 
const config = require('./config'); 
const app = module.exports = express(); 

const mass = massive.connectSync({connectionString: config.connectionString}); 

app.use(bodyParser.json()); 
app.use(cors()); 

//db settings 
app.set('db', mass); 
let db = app.get('db'); 

//The Controller for the server.js 
const controller = require('./mainCtrl.js'); 


app.get('/books', controller.GetBooks); 
app.get('/books/:id', controller.GetBook); 
app.get('/mypage/:id', controller.GetMyPage); 

app.delete('/mypage', function(req, res, next) { 
    console.log("req.body", req.body) 
    db.delete_mylist([req.body.book_id], function(err, individual) { 


     if(err) res.status(500).send(err); 
     else { 
      db.get_mypage_book(function(err, all) { 
       if(err) res.status(500).send(err); 
       else res.send(all); 
      }); 
     } 
    }); 
}); 

答えて

0

import axios from 'axios'; 

export const BOOK_SELECTED = 'BOOK_SELECTED'; 
export const GET_BOOKS = 'GET_BOOKS'; 
export const SIGN_UP_USER = 'SIGN_UP_USER'; 
export const LOGIN_USER = 'LOGIN_USER'; 
export const ADD_MYPAGE = 'ADD_MYPAGE'; 
export const GET_MYPAGE = 'GET_MYPAGE'; 
export const DELETE_BOOK = 'DELETE_BOOK'; 
export const LOGOUT_USER = 'LOGOUT_USER'; 


const ROOT_URL = 'http://localhost:3000/'; 

export function deleteBook(book_id, user_id) { 
    console.log("bookid", book_id, "user", user_id); 
    const request = axios.delete(`${ROOT_URL}mypage`, book_id, user_id); 
    return { 
     type: DELETE_BOOK, 
     payload: request 
    } 
} 

action.js HTTP仕様では、本体にDELETE要求でデータを送信しないでください。代わりに、ルートパラメータを使用してください:

app.delete('/mypage/:bookId', function(req, res, next) {...}); 
関連する問題