首页 文章

Angular 5使用Nodejs发布数据 - 正文格式错误

提问于
浏览
0

我使用nodejs作为angular 5应用程序的后端 . 当我使用http post请求发布数据时,它会在nodejs中以错误的形式出现(值为属性) - 这是我的角度5的服务代码 -

login(email: string, password: string) {
    let headers = new Headers({ 'Content-Type': 'application/x-www-form-urlencoded' });
    let options = new RequestOptions({ headers: headers });
    let body = { EmailAddress: email, Password: password };

    return this.http.post('http://localhost:3000/api/user/login', body, options )
        .map((response: Response) => {
            let user = response.json();
            if (user && user.token) {
                localStorage.setItem('currentUser', JSON.stringify(user));
            }
        });
}

这是Node API - 在体内我正在获得作为属性的 Value

app.post('/api/user/login', urlencodedBodyparser, function (req, res) {
    console.log(req.body);
    User.find({ "EmailAddress": req.body["EmailAddress"], "Password": req.body["Password"] }, function (err, users) {
        console.log(users.length);
        if (err != null) {
            sendError(err, res);
        }
        if (users != null) {
            var count = users.length;
            if (count > 0) {
                response.data = users[0];
                res.json(response);
            }
            else {
                sendError({ message :'No user found'}, res);
                console.log("Login Failed");
            }
        }
        else {
            sendError(err, res);
        }
    })
});

身体解析器的代码 -

var bodyParser = require('body-parser');

var urlencodedBodyparser = bodyParser.urlencoded({extended:false});

app.use(urlencodedBodyparser);

enter image description here

2 回答

  • 2

    尝试将 Headers 内容类型更改为json

    application / json

    像这样:

    options() {
            const headers = new Headers({
                'content-type': 'application/json'
            });
            const options = new RequestOptions({ headers: headers });
    
            return options;
        }
    
    
    
    
       login(): Observable<any> {
            return this.http.post('http://localhost:3000/api/user/login', this.options()).
                map((res: Response) => res.json());
        }
    
  • 1

    你需要使用body-parser中间件https://github.com/expressjs/body-parser
    这是更多信息What does body-parser do with express?
    试着用这个:

    app.use(bodyParser.json());
    app.use(bodyParser.urlencoded({extended: false}));
    

相关问题