Node.js中的HTTP请求与响应详解_node.js
在C#、OC中也是客户端发起一个请求,服务端作出响应。我们可以把这个过程抽象理解 .
- 1.客户端给服务端发起请求相当于向服务端写入一个流(writable)
- 2.服务端读取客户端的流(readable)
- 3.服务端向客户端作出响应相当于向客户端写入一个流(writable)
- 4.客户端读取服务端的响应(readable)
整个流程分为两部分一是客户端的处理而是服务端的处理.最主要的还是客户端请求和服务端响应.
一、http.ClientRequest对象
它实现了writable流,可以使用它的所有功能。http模块中使用http.request(options,callback)方法来生成该对象。
1.options主要包括以下几个可选:
host :服务器域名或IP地址,默认localhost
hostname:与host相同,但对url.parse()的支持优于host.
port:端口
localAddress:网络连接的本地接口
socketPath:Unix域套接字(使用host:port或socketPath)
method:请求方法 :GET、POST等默认GET
path:请求的资源路径默认/.也可包括查询字符串
headers:请求头
auth:身份认证
agent:代理.如果使用Agent,则请求默认为Connection:keep-alive.可能的值有undefined,Agent,false
2.ClientRequest提供的事件与方法
事件:
response:当从服务器收到该请求的响应时发出。该回调处理程序接收一个IncomingMessage对象作为唯一的参数。
socket:当一个套接字分配给该请求时发出。
connect:当服务器响应一个由CONNECT方法发起的一个请求时发出。如果该事件未被客户端处理,那么该连接将关闭
upgrade:当服务器响应在其标头包括一个更新请求的请求时发出
continue:当服务器发送一个100ContinueHTTP响应,指示客户端发送请求正文时发出
方法:
write()、end()和writable流一样
abort():终止请求。
setTimeout(timeout,[callback]):设置请求超时时间
setNoDelay([noDelay]):noDelay布尔值,true立即写入,false缓冲写入
setSocketKeepAlive([enable],[initualDelay]):启用和禁用对客户机请求的保持活动功能。initualDelay指定最后一个数据包和第一个保持活动请求之间的延迟。
二、http.ServerResponse对象
和http.ClientRequest对象一个也是实现了writable流。也可实现writable流的功能,另外还包括下面的事件属性和方法。
事件或属性:
- close:在Response.End()刷新响应之前关闭时发出。
- headersSent:布尔值.已发送为true.只读。
- sendDate:布尔值,true时,Date标头自动生成,并作为响应的一部分发送
- statusCode:无须显示的写入标头来指定响应状态码。
方法:
writeContinue():发送一个HTTP/1.1 100 Continue消息给客户端,请求被发送的正文内容
writeHead(statusCode,[reasonPhrase],[headers]):把一个响应标头写入请求。statusCode参数是HTTP响应状态代码,reasonPhrase是字符串,表示StatusCode的原因.headers是响应标头对象。response.writeHead(200,'Success',{'Content-Length':body.length,'Content-Type':'text/plain'});
setTimeout(msecs,callback):设置客户端连接的超时时间。
setHeader(name,value):设置标头值。
getHeader(name):获取标头值。
removeHeader(name):移除标头。
addTrailers(headers):将http尾随标头写入响应的结束处。
三、客户端响应和服务端请求
上面一二主要是writable流的,readable流的包括客户端响应和服务端请求。它们都是一个对象:IncomingMessage对象。
IncomingMessage对象长成什么样子可以把它输出来看.由于IncomingMessage对象对于我们开发的来说不经常用,所以看看就好。
var http=require("http") var options={ hostname:'www.baidu.com', path:'', port:'80', method:'GET' }; var req=http.request(options,function(response){ console.log(response); }); req.end();
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
相关文章:
- [前端]多版本node的安装和切换详细操作步骤_node.js
- [前端]使用nvm安装|更新|切换|nodejs的命令详解_node.js
- [前端]Nodejs中koa2连接mysql的实现示例_node.js
- [前端]node安装及环境变量配置详细教程_node.js
- [前端]npm install安装报错:gyp info it worked if it ends with ok的解决方法_node.js
- [前端]整理几个关键节点深入理解nodejs_node.js
- [前端]Node.js实现链式回调_node.js
- [前端]Node.js处理I/O数据之使用Buffer模块缓冲数据_node.js
- [前端]typescript在node.js下使用别名(paths)无效的问题详解_javascript技巧
- [前端]Node.js数据流Stream之Readable流和Writable流用法_node.js
相关推荐:
- [前端]Vue3 编写自定义指令插件的示例代码_vue.js
- [前端]vue使用element实现上传图片和修改图片功能_vue.js
- [前端]JS前端架构pnpm构建Monorepo方式管理demo_JavaScript
- [前端]Iconfont不能上传如何维护Icon_React
- [前端]jquery实现手风琴展开效果_jquery
- [前端]js前端实现word excel pdf ppt mp4图片文本等文件预览_JavaScript
- [前端]uniapp实现横屏签字版_javascript技巧
- [前端]微信小程序实现手写签名(签字版)_javascript技巧
- [前端]vue 大文件分片上传(断点续传、并发上传、秒传)_vue.js
- [前端]微信小程序实现日期范围选择_javascript技巧
- 如何在 JavaScript 中把字符串转换成数字
- 怎么理解ES6中Proxy及使用场景
- 详解vuex中的this.$store.dispatch方法
- javascript的call和apply的区别
- 为什么要使用Reflect对象
- 前端一些好学好用的代码规范-git hook+husky + commitlint
- 前端一些好学好用的代码规范-git hook+husky + commitlint
- 解决报错Node Sass does not yet support your current environment: Windows 64-bit with Unsupported
- mac安装nvm
- npm husky install .git can not be found解决方案
- CSS世界PDF电子版百度云网盘下载
- JavaScript权威指南(第6版)中文版PDF电子版百度云网盘下载
- Web服务 原理与技术[Michael P. Papazoglou]PDF电子版百度云网盘下载[44.7M]
- 基于TypeScript的HTML5游戏开发本科毕业设计PDF电子版百度云网盘下载
- 详解vue修改elementUI的分页组件视图没更新问题
- javascript的call和apply的区别
- WebKit技术内幕朱永盛PDF电子版百度云网盘下载
- JAVASCRIPT语言精髓与编程实践.周爱民.扫描版PDF电子版百度云网盘下载
- 精彩绝伦的CSS[Eric A. Meyer]PDF电子版百度云网盘下载[25.8M]
- HTML5与CSS3基础教程(第8版)[Elizabeth Castro]PDF电子版百度云网盘下载[72M]