将项目发布到JSON服务器数据库-Angular

时间:2019-05-27 06:05:02

标签: node.js angular express mean-stack json-server

我正在尝试将项目发布到json服务器中的数据库中。我正在从Angular发送POST请求。这样做时,出现以下错误:

注意:当我在GET端点中进行获取时,它工作正常。我在服务器端很新

  

POST错误404:   http://localhost:3000/addMember的Http错误响应:找不到404

SERVER.JS

const express = require('express');
const cors = require('cors');
const bodyParser = require('body-parser');
const request = require('request');
const app = express();
....

app.use(cors());
app.use(express.static('assets'));
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extended: true }));
app.disable('x-powered-by');
app.use(xssFilter());
app.use(nosniff());
app.set('etag', false);
app.use(
  helmet({
    noCache: true
  })
);
app.use(
  hsts({
    maxAge: 15552000 // 180 days in seconds
  })
);

app.use(
  express.static(path.join(__dirname, 'dist/softrams-racing'), {
    etag: false
  })
);

app.get('/api/members', (req, res) => {
  request('http://localhost:3000/members', (err, response, body) => {
    if (response.statusCode <= 500) {
      res.send(body);
    }
  });
});

// TODO: Dropdown!
app.get('/api/teams', (req, res) => {
  request('http://localhost:3000/teams', (err, response, body) => {
    if (response.statusCode <= 500) {
      res.send(body);
    }
  });
});

    // Submit Form!
    app.post('/api/members', function(request, response) {
  request.post('http://localhost:3000/members', (err, response, body) => {
    if (response.statusCode <= 500) {
      req.send(body);
    }
  });
});



  app.get('*', (req, res) => {
      res.sendFile(path.join(__dirname, 'dist/softrams-racing/index.html'));
    });

    app.listen('8000', () => {
      console.log('Vrrrum Vrrrum! Server starting!');
    });

英语

addMember(memberForm: Member) {
    this.http.post(`${this.api}/addMember`, memberForm).subscribe(
      data => {
        console.log('POST Request is successful ', data);
      },
      error => {
        console.log('Error', error);
      }
    );
  }

更新: 在我的控制台中,我看到此POST /addMember 404 12.105 ms - 2,如果我直接在浏览器中转到http://localhost:3000/addMember,我会看到一个空对象{},如果我在这里http://localhost:3000/,我会看到此消息< strong>要访问和修改资源,可以使用任何HTTP方法GET POST PUT PATCH DELETE OPTIONS

3 个答案:

答案 0 :(得分:2)

这里的问题是,您正在向JSON服务器无法处理的路由发出POST请求。将URL更改为http://localhost:3000/members,它应该可以正常工作!

(json服务器上的路由与您的db.json文件中的元素相对应。)

答案 1 :(得分:1)

尝试这样更改代码:

addMember(memberForm: Member) {
    this.http.post(`${this.api}/api/addMember`, memberForm).subscribe(
      data => {
        console.log('POST Request is successful ', data);
      },
      error => {
        console.log('Error', error);
      }
    );
  }

从错误中可以看出您的服务正在http://localhost:3000/api/addMember处请求请求,但是console.log显示您正在http://locatlhost:3000/addMember处发送请求请求

答案 2 :(得分:0)

您应该将代码更改为此,因为您希望ti获得memberForm数据

app.post('/api/addMember',function(request,response){
   var query1=request.body.memberForm;
});

如果您仍然有错误,请告诉我