前言
我们知道传统的HTPP服务器会由Aphche、Nginx、IIS之类的软件来担任,但是nodejs并不需要,nodejs提供了http模块,自身就可以用来构建服务器,而且http模块是由C++实现的,性能可靠。其中封装了一个高校的HTTP服务器和一个简单的HTTP客户端。http.Server是一个基于事件的HTTP服务器;http.request则是一个HTTP客户端工具,用于向HTTP服务器发送请求,实现内容抓取。
一. HTTP服务器
http.Server提供一套封装级别很低的API,仅仅是流控制和简单的消息解析。
可以使用http.CreateServer()来创建一个http.Server实例。
var http = require('http'); http.createServer(function (request, response){ response.writeHead(200, {'Content-Type': 'text/html'}); response。write("Server start!"); response.end('Hello World\n'); }).listen(8080, "127.0.0.1"); console.log('Server running on port 8080.');
http.createServer创建了一个http.Server实例,将一个函数作为HTTP请求处理函数。这个函数接受两个参数,分别是请求对象(req)和响应对象(res)。
二. http.ServerRequest
http.ServerRequest是HTTP请求信息。一般由http.Server的request事件发送,作为第一个参数传递。
HTTP请求一般分为两部分:请求头和请求体。
http.ServerRequest提供了以下3个事件用于控制请求体传输。
(1) data:当请求体数据到来时,该事件被触发。该事件提供一个参数trunk,表示接收到的数据。如果该事件没有被监听,那么请求体将会被抛弃;
(2) end:当请求体数据传输完成时触发;
(3) close:用户当前请求结束时触发。
ServerRequest的属性
三. 获取GET请求内容
http.ServerRequest提供的属性没有类似于PHP语言中的$_GET或$_POST的属性,那我们该如何接受客户端的表单请求呢?由于GET请求直接被嵌入在路径中,因此可以手动解释后面的内容作为GET请求的参数。
实例:
var http = require("http"); var url = require("url"); var util = require("util"); http.createServer(function(req, res) { res.writeHead(200, {"Content-Type": "text/html"}); res.end(util.inspect(url.parse(req.url, true))); }).listen(3000);
在浏览器中访问http://127.0.0.1:3000/?name=deng&age=22,返回结果如下:
Url { protocol: null, slashes: null, auth: null, host: null, port: null, hostname: null, hash: null, search: '?name=deng&age=22', query: { name: 'deng', age: '22' }, pathname: '/', path: '/?name=deng&age=22', href: '/?name=deng&age=22' }
通过url.parse,原始的path被解释为一个对象,其中query就是请求的内容。
四. 获取POST请求内容
POST请求的全部内容都在请求体中。
五. http.ServerReponse
http.ServerReponse是返回给客户端的信息,决定了用户最终能看到的结果,一般作为http.createServer(function(req, res) {})函数中的res参数传递。
http.ServerReponse有三个重要的成员函数,用于返回响应头、响应内容以及结束请求。
response.writeHead(statusCode, [headers]) :向请求的客户端发送响应头。statusCode是HTTP状态码,headers是一个表示响应头属性的对象;
response.write(data, [encoding]) :向请求的客户端发送相应内容。data表示要发送的内容,encoding表示编码方式(默认是utf-8);
response.end([data], [encoding]) :结束响应,告知客户端所有发送已经完成。当所有要返回的内容发送完毕的时候,该函数必须被调用一次。如果不调用该函数,客户端将永远处于等待状态。
六. HTTP客户端
http模块提供了两个函数http.request和http.get,作为客户端想HTTP服务器发起请求。
1. http.request()
http.request(options, callback)发起HTTP请求。
其中options的常用参数如下:
host:请求网站的域名或IP地址;
port:请求网站的端口,默认是80;
method:请求方法,默认是GET;
path:请求的相对于根的路径,默认是”/”;
headers:请求头的内容;
var http = require("http"); var querystring = require("querystring"); var contents = querystring.stringify({ name: "deng", age: 22 }); var options = { host: "dengzhr.com", method: "POST", headers: { "Content-Type": "application/x-www-form-urlencoded", "Content-Length": contents.length } }; var req = http.request(options, function(res) { res.setEncoding("utf8"); res.on("data", function(data) { console.log(data); }); }); req.write(contents); req.end();
在发送POST请求时,一定不要忘记通过req.end()结束请求,否则服务器将不会收到消息。
2. http.get()
http.get(options, callback)是http模块的用于处理GET请求的更加简便的方法。不需要手动调用req.end() 。
实例:
var http = require("http"); http.get({host: "dengzhr.com"}, function(res) { res.setEncoding("utf8"); res.on("data", function(data) { console.log(data); }); });
总结
以上就是这篇文章的全部内容了,希望能对大家的学习或者工作带来一定的帮助,如果有疑问大家可以留言交流。
本文向大家介绍深入理解node.js http模块,包括了深入理解node.js http模块的使用技巧和注意事项,需要的朋友参考一下 http模块主要用于搭建HTTP服务端和客户端,使用HTTP服务器或客户端功能都必须调用http模块。 创建服务器 对请求进行处理 请求分为两种:get和post,get请求url地址带参数,req.url便能获取参数,而post请求便复杂一些。使用req.on(
本文向大家介绍深入理解Nodejs Global 模块,包括了深入理解Nodejs Global 模块的使用技巧和注意事项,需要的朋友参考一下 浏览器上有自己的全局对象 window,同理, nodejs 下也有自己的全局对象 global,并且在各个模块下 都可以直接访问 global 对象。 在 nodejs 中,除了可以直接使用 V8 JavaScript 引擎中所支持的原生 JavaScr
本文向大家介绍深入理解Node中的buffer模块,包括了深入理解Node中的buffer模块的使用技巧和注意事项,需要的朋友参考一下 在Node、ES2015出现之前,前端工程师只需要进行一些简单的字符串或DOM操作就可以满足业务需要,所以对二进制数据是比较陌生。node出现以后,前端面对的技术场景发生了变化,可以深入到网络传输、文件操作、图片处理等领域,而这些操作都与二进制数据紧密相关。 No
本文向大家介绍深入浅析Nodejs的Http模块,包括了深入浅析Nodejs的Http模块的使用技巧和注意事项,需要的朋友参考一下 一、http服务器 我们知道传统的HTTP服务器是由Aphche、Nginx、IIS之类的软件来搭建的,但是Nodejs并不需要,Nodejs提供了http模块,自身就可以用来构建服务器,例如: http模块中封装了一个HTTP服务器和一个简易的HTTP客户端
本文向大家介绍深入理解Angular2 模板语法,包括了深入理解Angular2 模板语法的使用技巧和注意事项,需要的朋友参考一下 1. 说明 Angular2的模板用来显示组件外观,作为视图所用,用法和html语法基本一致,最简单的Angular2的模板就是一段html代码。Angular模板语法主要包括以下几个部分: l 直接绑定 l 插值表达 l 属性绑定 l 事件绑定 l 双向绑定 l 样
本文向大家介绍深入理解(function(){... })();,包括了深入理解(function(){... })();的使用技巧和注意事项,需要的朋友参考一下 1.他叫做立即运行的匿名函数(也叫立即调用函数) 2.当一个匿名函数被括起来,然后再在后面加一个括号,这个匿名函数就能立即运行起来!有木有很神奇哦~ 3.要使用一个函数,我们就得首先声明它的存在。而我们最常用的方式就是使用functio