node.js中http模块和url模块的简单介绍


Posted in Javascript onOctober 06, 2017

前言

本文主要给大家介绍了关于node.js中http模块与url模块的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧。

一、http模块的简单介绍

node.js当中的http内置模块可以用于创建http服务器与http客户端。

1、引包

const http = require('http');

2、创建http服务器

var server = http.createServer((req,res)=>{

});

使用http的.createServer()方法可以用于返回一个http服务器实例,用自定义的server变量来接收。当该服务器每次接收到客户端的请求时触发调用其内部的回调函数,客户端每访问一次,都会触发调用一次。该回调函数有两个参数,req和res,顺序不可颠倒,req表示请求request,res表示响应response。

该回调函数内部语句的一定要有res.end(); ,因为如果没有,浏览器会认为一直没有得到服务器的响应,则浏览器一直会处于被挂起的状态,此时浏览器内部有一个超时机制,一旦超时,则会报告错误。
该回调函数当中的常用代码语句有:

设置响应头,res.writeHead(状态码,{});其中HTTP状态码常用的有200(成功返回)、404(找不到该页面,返回错误)等。第二个参数传入一个对象,用于设置响应文本的渲染解析类型。如常用的有对于html代码设置为,res.writeHead(200,{"Content-Type":"text/html;charset=UTF8"}); 。对于css文件的设置为res.writeHead(200,{"Content-Type":"text/css"}); 。对于图片的设置为res.writeHead(200,{"Content-Type":"image/jpg"}); 。对于纯文本的设置为res.writeHead(200,{"Content-Type":"text/plain"});设置返回的内容,res.write('');

3、让该服务器监听特定的端口号

用server这个自定义的变量来表示创建的服务器来监听某个指定的端口号。server.listen(3000,'192.168.155.1');外界客户端可以通过这个ip地址和端口号来访问这个服务器。

node.js中http模块和url模块的简单介绍

此时表示该服务器处于挂起的状态,此时在浏览器当中输入对应的ip地址与端口号即可得到服务端响应的内容。

node.js中http模块和url模块的简单介绍

二、url模块的简单介绍

const http = require('http');
var server = http.createServer((req,res)=>{
 console.log(req.url);
 res.end();
});
server.listen(3000,'192.168.155.1');

使用node命令开启这个服务器时,可以在控制台实时打印出访问的客户端的url地址信息。

node.js中http模块和url模块的简单介绍

由于在通过chrome浏览器的方式在进行访问时,每次访问都会默认附带一次/favicon.ico的请求,在解析客户端真正在浏览器的访问地址时,可以做如下处理:

const http = require('http');
var server = http.createServer((req,res)=>{
 if(req.url == '/favicon.ico'){
  return;
 };
 console.log(req.url);
 res.end();
});
server.listen(3000,'192.168.155.1');

node.js中http模块和url模块的简单介绍

如上图所示,我们通过req.url可以得到用户完整的请求地址,我们可以利用内置的url模块对用户的请求地址进行解析。

1、引包

const url = require('url');

2、常用的是url.parse(req.url)

该方法常用的是把一个完整的url地址分解为一个对象。

const http = require('http');
const url = require('url');
var server = http.createServer((req,res)=>{
 if(req.url == '/favicon.ico'){
  return;
 };
 console.log(url.parse(req.url));
 res.end();
});
server.listen(3000,'192.168.155.1');

node.js中http模块和url模块的简单介绍

其中最常用的是url.parse(req.url).pathname得到一个文件路径的字符串,以/开头,并且不包括查询部分的内容。使用url.parse(req.url).query可以得到一个查询部分的字符串。其中url.parse()方法的第二个参数是true,可以将所有的查询变为对象形式。

console.log(url.parse(req.url,true).query);

node.js中http模块和url模块的简单介绍

通过这种方式可以快速得到客户端通过GET方式向服务器提交的数据。

总结

以上就是这篇文章的全部内容,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对三水点靠木的支持。

Javascript 相关文章推荐
Array.slice()与Array.splice()的返回值类型
Oct 09 Javascript
Jquery下的26个实用小技巧(jQuery tips, tricks & solutions)
Mar 01 Javascript
jQuery MD5加密实现代码
Mar 15 Javascript
JS代码放在head和body中的区别分析
Dec 01 Javascript
JS检测图片大小的实例
Aug 21 Javascript
JS复制内容到剪切板的实例代码(兼容IE与火狐)
Nov 19 Javascript
jQuery简单动画变换效果实例分析
Jul 04 Javascript
JavaScript使用ZeroClipboard操作剪切板
May 10 Javascript
尝试自己动手用react来写一个分页组件(小结)
Feb 09 Javascript
vue2实现搜索结果中的搜索关键字高亮的代码
Aug 29 Javascript
jQuery选择器之基本过滤选择器用法实例分析
Feb 19 jQuery
vue插件mescroll.js实现移动端上拉加载和下拉刷新
Mar 07 Javascript
你应该知道的几类npm依赖包管理详解
Oct 06 #Javascript
vue-cli构建项目使用 less的方法
Oct 04 #Javascript
浅谈Angular2 模块懒加载的方法
Oct 04 #Javascript
浅谈angular2路由预加载策略
Oct 04 #Javascript
浅谈Angular路由复用策略
Oct 04 #Javascript
React-Native之定时器Timer的实现代码
Oct 04 #Javascript
vuejs使用$emit和$on进行组件之间的传值的示例
Oct 04 #Javascript
You might like
DC《神奇女侠2》因疫情推迟上映 温子仁新恐怖片《恶性》撤档
2020/04/09 欧美动漫
PHP生成等比缩略图类和自定义函数分享
2014/06/25 PHP
php字符串操作针对负值的判断分析
2016/07/28 PHP
php判断电子邮件是否正确方法
2018/12/04 PHP
CentOS7系统搭建LAMP及更新PHP版本操作详解
2020/03/26 PHP
Prototype使用指南之enumerable.js
2007/01/10 Javascript
用jQuery技术实现Tab页界面之二
2009/09/21 Javascript
JQuery下的Live方法和$.browser方法使用代码
2010/06/02 Javascript
用jquery设置按钮的disabled属性的实现代码
2010/11/28 Javascript
jquery蒙版控件实现代码
2010/12/08 Javascript
用jquery写的菜单从左往右滑动出现
2014/04/11 Javascript
JS实现往下不断流动网页背景的方法
2015/02/27 Javascript
nodejs URL模块操作URL相关方法介绍
2015/03/03 NodeJs
jquery仿百度百科底部浮动导航特效
2015/08/08 Javascript
VUE长按事件需求详解
2017/10/18 Javascript
解决vue 路由变化页面数据不刷新的问题
2018/03/13 Javascript
jQuery事件多次绑定与解绑问题实例分析
2019/02/19 jQuery
轻松解决JavaScript定时器越走越快的问题
2019/05/13 Javascript
微信小程序自定义波浪组件使用方法详解
2019/09/21 Javascript
vue实现手机端省市区区域选择
2019/09/27 Javascript
DWR内存兼容及无法调用问题解决方案
2020/10/16 Javascript
python抓取网页图片示例(python爬虫)
2014/04/27 Python
Windows下为Python安装Matplotlib模块
2015/11/06 Python
python jieba分词并统计词频后输出结果到Excel和txt文档方法
2018/02/11 Python
Python assert关键字原理及实例解析
2019/12/13 Python
Pytorch根据layers的name冻结训练方式
2020/01/06 Python
HTML5使用ApplicationCache接口实现离线缓存技术解决离线难题
2012/12/13 HTML / CSS
Melijoe时尚童装德国官网:Melijoe德国
2016/09/03 全球购物
西班牙宠物用品和食品网上商店:Tiendanimal
2019/06/06 全球购物
大学旷课检讨书
2014/01/28 职场文书
未婚证明书模板
2014/10/08 职场文书
2015年导购员工作总结
2015/04/25 职场文书
追悼词范文大全
2015/06/23 职场文书
远程教育学习心得体会
2016/01/23 职场文书
简单实现一个手持弹幕功能+文字抖动特效
2021/03/31 HTML / CSS
Nginx设置日志打印post请求参数的方法
2021/03/31 Servers