nodeJS:无法在浏览器中打开响应-说页面无法正常工作

时间:2019-03-31 05:22:35

标签: node.js express restful-url

我已经使用node.js创建了RestAPI作为连接MySQL服务器的连接,连接成功,但是当我请求URL时,浏览器会继续加载并说this page is not working

const mysql = require('mysql');
const express = require('express');
const bodyparser = require('body-parser');

var app = express();
app.use(bodyparser.json)
var mySqlConnection = mysql.createConnection({
host :'db4free.net',
user:'username',
password:'password',
database:'db'

});

mySqlConnection.connect((err)=>{
if(!err)
console.log('success');
else
console.log('failed' +JSON.stringify(err,undefined,2));
});


app.listen(3000,()=>console.log('Express server is running at port 
3000'));

app.get('/tasks',(res,req)=>{
mySqlConnection.query('SELECT * FROM tasks',(err,rows,fields)=>{
 if(!err)
 console.log(rows[0]);
 else
 console.log(err);
})
});

当我尝试使用URL localhost:3000/tasks时,浏览器中没有任何内容。预期的输出是打开URL localhost:3000/tasks时,应在控制台中记录数据行,但URL本身未打开。

1 个答案:

答案 0 :(得分:1)

您没有调用bodyparser.json函数,该函数将返回中间件以进行请求解析。您必须像下面这样包含它:

app.use(bodyParser.json());

此外,您还必须通过发送数据或使用req.jsonreq.end结束请求来结束在浏览器中加载数据的请求。您必须在函数参数中交换req,res对象,因为reqres之前。

app.get('/tasks',(req, res)=>{
    console.log('fefefe')
    mySqlConnection.query('SELECT * FROM tasks',(err,rows,fields)=>{
        if(!err)
            console.log(rows[0]);
        else
            console.log(err);
        res.send({d: rows[0]})
    })
});