node js表示3 app.post不工作

时间:2015-01-06 16:09:36

标签: mysql ajax node.js express

我在尝试发帖时遇到问题。我的app.get工作得很好,但我不能对帖子说同样的话。这是我的server.js

// Express is the web framework 
var express = require('express');
var app = express();
app.use(express.bodyParser());
app.configure(function () {
  app.use(allowCrossDomain);
});

app.post('/server/orders',express.bodyParser(), function(req, res) { 
     alert("Estamoooo");
    console.log("POST Order"); 
    var client = mysql.createConnection({
    host     : 'localhost',
    database : "DB",
    user     : 'root',
    password : 'XXXX'
    });
    client.connect(); 


    var name = req.body.name; 
    var lastname = req.body.lastname; 
    var telephone = req.body.telephone; 
    var address = req.body.address; 
    var queso = req.body.queso; 
    var vainilla = req.body.vainilla; 
    var date = req.body.date;


    var query = client.query("insert into orden(name,lastname,telephone,address,queso,vainilla,date) values('"  
    + name + "', '" + lastname +"','"+ telephone +"'  , "+ address + ", '" + queso + "', "+ vainilla +", '" + date  
    +"' );"); 
    query.on("end", function (result) { 
        client.end(); 
        res.json(true); 
    }); 

 }); 

这是我的appjs.js

function addOrder(){ 
    var newOrder = {}; 
    newOrder.name = document.getElementById("nombre").value; 
    newOrder.lastname = document.getElementById("apellido").value; 
    newOrder.telephone = document.getElementById("telefono").value; 
    newOrder.address = document.getElementById("direccion").value; 
    newOrder.queso = document.getElementById("cantidadQueso").value; 
    newOrder.vainilla = document.getElementById("cantidadVainilla").value; 
    newOrder.date = document.getElementById("fecha").value; 

    var newOrderJSON = JSON.stringify(newOrder); 
    alert("New Order: " + newOrderJSON);
    $.ajax({
        url : "http://192.168.0.1:8020/server/orders",
        method: 'post',
        data : newOrderJSON,
        contentType: "application/json",
        dataType:"json",
        success : function(data, textStatus, jqXHR){
            alert("Data Added!!!");
        },
        error: function(data, textStatus, jqXHR){
            alert("Data could not be added!");
        }
        }); 
 } 

没有调用ajax。我没有得到回应,没有任何反应。这很奇怪,因为get工作真的很棒。谢谢!

更新:我知道服务器端运行良好。问题出在appjs代码中。它正在跳过ajax调用。

2 个答案:

答案 0 :(得分:0)

我想你忘记了app.listen(8020);部分。

我测试了以下示例:

// Express is the web framework 
var express = require('express');
var app = express();
app.use(express.bodyParser());

app.post('/server/orders',express.bodyParser(), function(req, res) { 
    console.log("POST Order"); 

    var name = req.body.name; 
    var lastname = req.body.lastname; 
    var telephone = req.body.telephone; 
    var address = req.body.address; 
    var queso = req.body.queso; 
    var vainilla = req.body.vainilla; 
    var date = req.body.date;

    console.log(name, lastname, telephone, address, queso, vainilla, date);

    res.send('works');
 });

app.listen(8020);

使用以下命令:

curl -v -XPOST 'localhost:8020/server/orders' -d "name=name value&lastname=lastname value&telephone=telephone value&address=address value&queso=queso value&vainilla=vainilla value&date=date value"
* Hostname was NOT found in DNS cache
*   Trying 127.0.0.1...
* Connected to localhost (127.0.0.1) port 8020 (#0)
> POST /server/orders HTTP/1.1
> User-Agent: curl/7.35.0
> Host: localhost:8020
> Accept: */*
> Content-Length: 145
> Content-Type: application/x-www-form-urlencoded
> 
* upload completely sent off: 145 out of 145 bytes
< HTTP/1.1 200 OK
< X-Powered-By: Express
< Content-Type: text/html; charset=utf-8
< Content-Length: 5
< Date: Tue, 06 Jan 2015 16:42:35 GMT
< Connection: keep-alive
< 
* Connection #0 to host localhost left intact
works%  

你可以看到它有效。

答案 1 :(得分:0)

我忘了将include放在我的jquery的html上,这就是为什么跳过了ajax代码块。