深入理解node.js http模塊
http模塊主要用于搭建HTTP服務端和客戶端,使用HTTP服務器或客戶端功能都必須調用http模塊。
創(chuàng)建服務器
var http = require(“http”);var url = require(“url”);//創(chuàng)建服務器//http繼承自tcpvar server = http.createServer(function (req,res) { var urlstr = req.url;//獲取請求的路徑 var urlMethod = req.method;//獲取請求的方法 var urlObj = url.parse(urlstr,true); console.log(urlObj);
console.log(urlMethod); res.end(“hello”);});server.listen(8080);
對請求進行處理
請求分為兩種:get和post,get請求url地址帶參數,req.url便能獲取參數,而post請求便復雜一些。使用req.on()處理post請求。
post請求方式:使用req.on("data"function(){})方式讀取,使用str字符串拼接,在req.on("end",function(){})讀取結束后輸出str便是我們想得到的post請求發(fā)送的參數;
get請求方式:在請求地址上使用url.parse(req.url,true).query得到參數。
var http = require("http");
var fs = require("fs");
var url = require("url");
var querystring = require("querystring");
var server = http.createServer(function (req,res) {
console.log(req.method);
var pathname = url.parse(req.url,true).pathname;
if(pathname=="/"){
// 加載注冊頁面
var rs = fs.createReadStream("post.html");
rs.pipe(res);
}else if(pathname=="/post"){
// 處理post請求
var str = "";
req.on("data",function (chunk) {
// console.log(chunk.toString());
str += chunk;
});
req.on("end",function(){
var postObj = querystring.parse(str);
console.log(postObj);
})
}else if(pathname=="/get"){
// get請求
var getObj = url.parse(req.url,true).query;
res.write(JSON.stringify(getObj));
res.end();
}else if(pathname!="/favicon.ico"){
var rs = fs.createReadStream("."+pathname);
rs.pipe(res);
};
});
server.listen(8787);
上傳文件處理
前端html代碼如下:就不細說了。
<form action=“/upimg” method=“post” enctype=“multipart/form-data”> 用戶名: <input type=“text” name=“user”><br> 密碼: <input type=“password” name=“pass”><br> 上傳圖片: <input type=“file” name=“file1”><br> <input type=“submit” value=“提交”></form>
想要實現文件上傳,要引入formidable模塊var formidable = require("formidable");若是沒有此模塊,在終端輸入 npm install formidable安裝。
form.parse(req,function(err,fields,fies){})方法回調函數的三個參數
- err:返回錯誤信息
- fields:post請求返回的字段以及對應的值
- fies:上傳的文件對象,對象中包含文件的很多詳細信息
得到文件信息后,使用數據流的讀和寫復制文件
var http = require("http");
var fs = require("fs");
var url = require("url");
// 文件上傳
var formidable = require("formidable");
var server = http.createServer(function(req,res){
var pathname = url.parse(req.url,true).pathname;
if(pathname=="/"){
var rs = fs.createReadStream("uploads.html");
rs.pipe(res);
}else if(pathname=="/uploads"){
// 實例化一個formidable類
var form = new formidable.IncomingForm();
// 調用parse方法
form.parse(req,function(err,fields,files){
if(err){
return console.log(err);
}else{
// console.log("字段",fields);
// 存儲字段
var fieldStr = JSON.stringify(fields);
fs.writeFileSync("1.txt",fieldStr);
// 轉存文件
if(!fs.existsSync("uploads")){
fs.mkdir("uploads");
}
// 隨機路徑
var filePath = files.img.path;
var rs = fs.createReadStream(filePath);
var ws = fs.createWriteStream("./uploads/"+files.img.name);
rs.pipe(ws);
rs.on("data",function (chunk) {
})
rs.on("end",function(){
console.log("復制成功");
res.write("上傳成功");
res.end();
})
res.setHeader("Content-type","text/html;charset=utf8");
console.log("文件",files);
}
})
}else if(pathname!="/favicon.ico"){
var rs = fs.createReadStream("."+pathname);
rs.pipe(res);
}
});
server.listen(8880);
http模擬客戶端
主要是options的配置,最基本的參數如下面的代碼塊。
- method:說明請求方式;
- host: 服務器ip,這里以本地localhost為例;
- port:服務器端口號;
- path:請求路徑;
此時不在使用http.createServer()創(chuàng)建服務器了,而是使用http.request()請求服務器,其余的都和服務器差不多了。
// 通過nodejs模擬客戶端
var http = require("http");
var options = {
method:"post",
host:"localhost",
port:2121,
path:"/"
};
var request = http.request(options,function (res) {
var str = "";
res.on("data",function(chunk){
str += chunk;
});
res.on("end",function () {
console.log(str);
})
});
var obj = {
name:"李四",
age:20
}
request.write(JSON.stringify(obj));
request.end();
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
node.js中fs.stat與fs.fstat的區(qū)別詳解
fs.stat和fs.fstat他們都是用來獲取文件的狀態(tài)信息,下面這篇文章主要給大家介紹了關于node.js中fs.stat與fs.fstat區(qū)別的相關資料,文中介紹的非常詳細,對大家具有一定的參考學習價值,需要的朋友們下面來一起看看吧。2017-06-06
詳解express使用vue-router的history踩坑
這篇文章主要介紹了express 使用 vue-router 的 history 踩坑,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2019-06-06
Node.js環(huán)境下JavaScript實現單鏈表與雙鏈表結構
Node環(huán)境下通過npm可以獲取list的幾個相關庫,但是我們這里注重于自己動手實現,接下來就一起來看一下Node.js環(huán)境下JavaScript實現單鏈表與雙鏈表結構2016-06-06

