摘要
在很多情況下,我們的web服務器都需要接受客戶端瀏覽器傳遞的參數或者數據。最常見的是get和post請求。
獲取get請求的內容
get請求傳遞的參數在url中,參數部分在?后面。因此可以手動解析后面的內容作為get請求的參數。node.js中url模塊中的parse函數提供了這個功能。
一個例子
var http=require("http"); var url=require("url"); var util=require("util"); http.createServer(function(request,response){response.writeHead(200,{"Content-Type":"text/plain"});response.end(util.inspect(url.parse(request.url,true))); }).listen(5544);
啟動服務器
瀏覽器訪問
使用parse解析url中的參數
webserver.js核心代碼如下:
var http=require("http"); var url=require("url"); var util=require("util"); function start(route){function onRequest(request,response){response.writeHead(200,{"Content-Type":"text/plain"});//解析url參數var params=url.parse(request.url,true).query;response.write("my name is "+params.name);response.end();};http.createServer(onRequest).listen(5544);console.log("web server has started."); }; exports.start=start;
route.js代碼如下:
function route(pathname){console.log("request the route "+pathname); }; exports.route=route;
user.js代碼如下
var server=require("./webserver"); var router=require("./router"); server.start(router.route);
啟動webserver
瀏覽器瀏覽
post請求
post請求的內容全部在請求體中,http.ServerRequest并沒有一個屬性內容為請求體,原因是等待請求體傳輸可能是一件耗時的工作。
比如上傳文件,而很多時候我們可能并不需要理會請求體內容,惡意的post請求會大大消耗服務器資源,所以node.js默認是不會解析請求體的,當你需要的時候,需要手動來做。
一個例子
var http=require("http"); var url=require("url"); var util=require("util"); var querystring=require("querystring"); function start(route){function onRequest(request,response){//定義一個post變量,用于暫時村塾請求體信息。var post='';//通過request的data事件監聽函數,每當接受到請求的數據,就累加到post變量中request.on("data",function(chunk){post+=chunk;});//在end事件觸發后,通過querystring.parse將post解析為真正的post請求格式,
然后想客戶端返回。request.on("end",function(){post=querystring.parse(post);response.end(util.inspect(post));});response.writeHead(200,{"Content-Type":"text/plain"});//解析url參數var params=url.parse(request.url,true).query;response.write("my name is "+params.name);response.end();};http.createServer(onRequest).listen(5544);console.log("web server has started."); }; exports.start=start;
學習資料
http://www.runoob.com/nodejs/node-js-get-post.html