web-dev-qa-db-ja.com

Node.jsでajaxポストから成功を返す方法

私はこのような機能を持っています:

exports.saveAction = function (req, res) {
    var conn = mysql.createConnection({
        Host     : nconf.get("database:Host"),
        //port: 3306,
        user     : nconf.get("database:username"),
        password : nconf.get("database:password"),
        database : nconf.get("database:database"),
        multipleStatements: true,
        //ssl: 'Amazon RDS'
    });
    var action = req.body;   
    conn.query('UPDATE actions SET ? WHERE Id = ?', 
                  [action, action.Id], function (err, result) {
        conn.end();
        if (err) throw err;
        res.writeHead(200, { "Content-Type": "application/json" });
        res.end("Updated Successfully");
    });
};

「200」を返しますが、常に次のエラー句で返されます。

$.ajax({
    url: "/api/action/SaveAction",
    type: "PUT",
    data: ko.toJSON(self.stripDownObj()),
    datatype: "json",
    contentType: "application/json; charset=utf-8",
    success: function (result) {
        console.log(result);
        if(result.status == 200){
            self.isEditMode(!self.isEditMode());
        }
    },
    error: function(result){
        console.log(result);
    }
});

注:SQLクエリは成功し、データを保存します。

13
jmogera

JSONを期待しているときにJSONを返す

res.end('{"success" : "Updated Successfully", "status" : 200}');

その後

$.ajax({
     ....
    datatype: "json", // expecting JSON to be returned

    success: function (result) {
        console.log(result);
        if(result.status == 200){
            self.isEditMode(!self.isEditMode());
        }
    },
    error: function(result){
        console.log(result);
    }
});

Nodeでは、常にJSON.stringifyを使用して有効なJSONを取得することもできます

var response = {
    status  : 200,
    success : 'Updated Successfully'
}

res.end(JSON.stringify(response));

Expressはまた、

res.json({success : "Updated Successfully", status : 200});

オブジェクトをJSONに変換し、適切なヘッダーを自動的に渡します。

30
adeneo