server.js:
    var express = require('express');
    var app = express();
    loggedIn = {};
    app.use('/',express.static('www')); // static files
    app.listen(8080, function () {
      console.log('Port 8080!');
    });
    app.get('/user', function(req, res) {
        if (typeof req.param('user') != 'undefined') {
            user = req.param('user');
            res.status(200).send('Works');
        }
    });
    app.post('/user', function(req, res) {
            user = req.param('user');
            if (typeof users[user] != 'undefined') {
                return res.status(405).send('Access Forbidden');
            } else {
                   loggedIn[user] = "";
                   res.status(201).send('New User');
            }
        }
    });
client.js requests:
    $.ajax({
        method: "GET",
        url: "/user",
        data: {"user" : user},
        dataType: "application/json",
        success: function(data) {
            // success
        },
        error: function() {
            // error case
        }
    });
    $.ajax({
        method: "POST",
        url: "/user",
        data: {"user" : user},
        dataType: "application/json",
        success: function(data) {
            // success
        },
        error: function() {
            // error case
        }
    });
Even though the GET request works exactly as expected and passes the parameter here, for some reason, the post request doesn't. In firebug, I notice the POST request receives no parameters whatsoever (POST user) while GET request does (GET user?user=XYZ). I am really at a loss right now.
 
     
    