本文实例讲述了node.js使用http模块创建服务器和客户端。分享给大家供大家参考,具体如下:
node.js中的 http 模块提供了创建服务器和客户端的方法,http 全称是超文本传输协议,基于 tcp 之上,属于应用层协议。
一、创建http服务器
const http = require('http'); //创建一个http服务器 let server = http.createServer(); //监听端口 server.listen(8888, '0.0.0.0'); //设置超时时间 server.setTimeout(2 * 60 * 1000); //服务器监听时触发 server.on('listening', function () { console.log('监听开始'); }); //接收到客户端请求时触发 server.on('request', function (req, res) { //req表示客户端请求对象,是http.IncomingMessage类的实例,可读流。 //res表示服务端响应对象,是http.ServerResponse类的实例,可写流。 //请求方法 console.log(req.method); //请求url console.log(req.url); //请求的头信息 console.log(req.headers); //请求的http版本 console.log(req.httpVersion); //请求对象的socket对象 console.log(req.socket); res.end('hello'); }); //连接建立时触发 server.on('connection', function (socket) { console.log('建立连接'); }); //客户端向服务器发送CONNECT请求时触发 server.on('connect', function (req, socket, head) { console.log('客户端connect'); }); //服务器关闭时触发,调用 close() 方法。 server.on('close', function () { console.log('服务器关闭'); }); //发生错误时触发 server.on('error', function (err) { console.log(err); }); //如果连接超过指定时间没有响应,则触发。 //超时后,不可再复用已建立的连接,需发请求重新建立连接 server.on('timeout', function (socket) { console.log('连接已超时'); });
请求对象 req 里保存了客户端的详细信息,包括 url,请求参数等,为了方便的解析这些参数,我们可以使用 url.parse() 方法。
const http = require('http'); const url = require('url'); //创建一个http服务器 let server = http.createServer(); //监听端口 server.listen(8888, '0.0.0.0'); //接收到客户端请求时触发 server.on('request', function (req, res) { //解析url返回一个url对象 //如果参数二设为true,则url对象中的query属性将通过querystring.parse()生成一个对象 let params = url.parse(req.url, true); //完整url地址 console.log('href', params.href); //主机名,包含端口 console.log('host', params.host); //主机名,不包含端口 console.log('hostname', params.hostname); //端口 console.log('port', params.port); //协议 console.log('protocol', params.protocol); //路径,包含查询字符串 console.log('path', params.path); //路径,不包含查询字符串 console.log('pathname', params.pathname); //查询字符串,不包含 "htmlcode">const http = require('http'); const url = require('url'); //创建一个http服务器 let server = http.createServer(); //监听端口 server.listen(8888, '0.0.0.0'); //接收到客户端请求时触发 server.on('request', function (req, res) { //设置响应头信息 res.setHeader('Content-Type', 'text/html;charset=utf-8'); //获取响应头信息 res.getHeader('Content-Encoding'); res.setHeader('test', 'test'); //删除响应头信息 res.removeHeader('test'); //判断响应头是否已发送 console.log(res.headersSent "htmlcode">const http = require('http'); const zlib = require('zlib'); let client = http.request({ //协议 'protocol': 'http:', //主机名或IP 'hostname': 'www.baidu.com', //端口 'port': 80, //请求方式 'method': 'GET', //请求路径和查询字符串 'path': '/', //请求头对象 'headers': { 'Accept-Encoding': 'gzip, deflate, br' }, //超时时间 'timeout': 2 * 60 * 1000 }); //发送请求 client.end(); //响应被接收到时触发 client.on('response', function (res) { console.log('状态吗:' + res.statusCode); console.log('响应头:' + JSON.stringify(res.headers)); //头信息的名称为小写 let encoding = res.headers['content-encoding']; //判断响应头中的内容编码,是否有过压缩,如果有则进行解压 if (encoding.match(/\bgzip\b/)) { res.pipe(zlib.createGunzip()).pipe(process.stdout); } else if (encoding.match(/\bdeflate\b/)) { res.pipe(zlib.createInflate()).pipe(process.stdout); } else { res.pipe(process.stdout); } }); //请求过程中出错了触发 client.on('error', function (err) { console.log(err); }); //当 socket 被分配到请求后触发 client.on('socket', function (socket) { socket.setTimeout(2 * 60 * 1000); socket.on('timeout', function () { //终止本次请求 client.abort() }); });也可以使用 http.get() 简便方法进行 get 请求。
const http = require('http'); //会自动调用 req.end(),默认为 get 请求。 http.get('http://www.baidu.com', function (res) { res.on('data', function (data) { console.log(data.toString()); }); });希望本文所述对大家node.js程序设计有所帮助。
华山资源网 Design By www.eoogi.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
华山资源网 Design By www.eoogi.com
暂无评论...
P70系列延期,华为新旗舰将在下月发布
3月20日消息,近期博主@数码闲聊站 透露,原定三月份发布的华为新旗舰P70系列延期发布,预计4月份上市。
而博主@定焦数码 爆料,华为的P70系列在定位上已经超过了Mate60,成为了重要的旗舰系列之一。它肩负着重返影像领域顶尖的使命。那么这次P70会带来哪些令人惊艳的创新呢?
根据目前爆料的消息来看,华为P70系列将推出三个版本,其中P70和P70 Pro采用了三角形的摄像头模组设计,而P70 Art则采用了与上一代P60 Art相似的不规则形状设计。这样的外观是否好看见仁见智,但辨识度绝对拉满。
更新日志
2024年11月14日
2024年11月14日
- 16层乐队.2024-大快朵颐【摩登天空】【FLAC分轨】
- 群星.1988-电视金曲巡礼【EMI百代】【WAV+CUE】
- 群星.1992-电视金曲巡礼VOL.2【EMI百代】【WAV+CUE】
- 廖昌永《情缘HQ》头版限量[低速原抓WAV+CUE]
- 蔡琴《老歌》头版限量编号MQA-24K金碟[低速原抓WAV+CUE]
- 李嘉《国语转调》3CD[WAV+CUE]
- 谭咏麟《爱的根源 MQA-UHQCD》2022头版限量编号 [WAV+CUE][1G]
- 江洋 《江洋原创琵琶作品专辑》[320K/MP3][118.08MB]
- 江洋 《江洋原创琵琶作品专辑》[FLAC/分轨][228.33MB]
- 《战舰世界》语音包文件夹位置介绍
- 《CSGO》送好友皮肤方法介绍
- 《山羊模拟器重制版》发售平台说明
- 刘德华2002-美丽的一天[香港首批大包装首版][WAV]
- 刘文正《金装刘文正不朽经典金曲》2CD(1995环星)][WAV+CUE]
- 周慧敏《94美的化身演唱会》宝丽金1995港版2CD[WAV+CUE]