深入理解node.js http模块


Posted in Javascript onJanuary 24, 2018

http模块主要用于搭建HTTP服务端和客户端,使用HTTP服务器或客户端功能都必须调用http模块。

创建服务器

var http = require(“http”);var url = require(“url”);//创建服务器//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请求发送的参数;

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){})方法回调函数的三个参数

  1. err:返回错误信息
  2. fields:post请求返回的字段以及对应的值
  3. 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的配置,最基本的参数如下面的代码块。

  1. method:说明请求方式;
  2. host: 服务器ip,这里以本地localhost为例;
  3. port:服务器端口号;
  4. path:请求路径;

此时不在使用http.createServer()创建服务器了,而是使用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();

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
不要在cookie中使用特殊字符的原因分析
Jul 13 Javascript
读jQuery之二(两种扩展)
Jun 11 Javascript
Jquery中显示隐藏的实现代码分析
Jul 26 Javascript
利用div+jquery自定义滚动条样式的2种方法
Jul 18 Javascript
深入浅出理解javaScript原型链
May 09 Javascript
深入浅出ES6之let和const命令
Aug 25 Javascript
jQuery Plupload上传插件的使用
Apr 19 jQuery
ES6新特性八:async函数用法实例详解
Apr 21 Javascript
JavaScript实现一个空中避难的小游戏
Jun 06 Javascript
vue.js中实现登录控制的方法示例
Apr 23 Javascript
详解Vue+elementUI build打包部署后字体图标丢失问题
Jul 13 Javascript
HTML元素拖拽功能实现的完整实例
Dec 04 Javascript
微信、QQ、微博、Safari中使用js唤起App
Jan 24 #Javascript
基于node打包可执行文件工具_Pkg使用心得分享
Jan 24 #Javascript
Angular整合zTree的示例代码
Jan 24 #Javascript
使用classList来实现两个按钮样式的切换方法
Jan 24 #Javascript
基于vue.js 2.x的虚拟滚动条的示例代码
Jan 23 #Javascript
AngularJS基于http请求实现下载php生成的excel文件功能示例
Jan 23 #Javascript
简述vue中的config配置
Jan 23 #Javascript
You might like
php中使用preg_match_all匹配文章中的图片
2013/02/06 PHP
php中get_defined_constants函数用法实例分析
2015/05/12 PHP
PHP文件系统管理(实例讲解)
2017/09/19 PHP
WHOOPS PHP调试库的使用
2017/09/29 PHP
PHP工厂模式简单实现方法示例
2018/05/23 PHP
禁止直接访问php文件代码分享
2020/05/05 PHP
jquery 获取json数据实现代码
2009/04/27 Javascript
ExtJS 刷新后如何默认选中刷新前最后一次选中的节点
2014/04/03 Javascript
Javascript玩转继承(三)
2014/05/08 Javascript
jQuery插件pagewalkthrough实现引导页效果
2015/07/05 Javascript
AngularJS基础教程之简单介绍
2015/09/27 Javascript
jQuery实时显示鼠标指针位置和键盘ASCII码
2016/03/28 Javascript
webpack打包react项目的实现方法
2018/06/21 Javascript
在Node.js下运用MQTT协议实现即时通讯及离线推送的方法
2019/01/24 Javascript
vue实现歌手列表字母排序下拉滚动条侧栏排序实时更新
2019/05/14 Javascript
微信小程序云开发之数据库操作
2019/05/18 Javascript
微信小程序非跳转式组件授权登录的方法示例
2019/05/22 Javascript
如何使用CSS3+JQuery实现悬浮墙式菜单
2019/06/18 jQuery
vue-router 按需加载 component: () =&gt; import() 报错的解决
2020/09/22 Javascript
Nodejs在局域网配置https访问的实现方法
2020/10/17 NodeJs
[01:12]DOTA2 2015年秋季互动指南
2015/11/10 DOTA
python学习数据结构实例代码
2015/05/11 Python
Python的组合模式与责任链模式编程示例
2016/02/02 Python
django实现登录时候输入密码错误5次锁定用户十分钟
2017/11/05 Python
python实现比较文件内容异同
2018/06/22 Python
对pandas的层次索引与取值的新方法详解
2018/11/06 Python
松本清官方海外旗舰店:日本最大的药妆连锁店
2017/11/21 全球购物
Kusmi茶美国官网:优质散叶茶和茶包
2019/10/13 全球购物
南京软件公司的.net程序员笔试题
2014/08/31 面试题
中专毕业个人的自荐信格式
2013/09/21 职场文书
先进个人获奖感言
2014/01/24 职场文书
入党自我评价优缺点
2014/01/25 职场文书
关于环保的标语
2014/06/13 职场文书
公司禁烟通知
2015/04/23 职场文书
python 模块重载的五种方法
2021/04/24 Python
分享提高 Python 代码的可读性的技巧
2022/03/03 Python