Node.js中HTTP模块的用法的相关知识有什么
Admin 2022-10-19 群英技术资讯 279 次浏览
Node.js开发的目的就是为了用JavaScript编写Web服务器程序。因为JavaScript实际上已经统治了浏览器端的脚本,其优势就是有世界上数量最多的前端开发人员。如果已经掌握了JavaScript前端开发,再学习一下如何将JavaScript应用在后端开发,就是名副其实的全栈了。
要理解Web服务器程序的工作原理,首先,我们要对HTTP协议有基本的了解。如果你对HTTP协议不太熟悉,先看一看HTTP协议简介。
要开发HTTP服务器程序,从头处理TCP连接,解析HTTP是不现实的。这些工作实际上已经由Node.js自带的http模块完成了。应用程序并不直接和HTTP协议打交道,而是操作http模块提供的request和response对象。
request对象封装了HTTP请求,我们调用request对象的属性和方法就可以拿到所有HTTP请求的信息;
response对象封装了HTTP响应,我们操作response对象的方法,就可以把HTTP响应返回给浏览器。
用Node.js实现一个HTTP服务器程序非常简单。我们来实现一个最简单的Web程序hello.js,它对于所有请求,都返回Hello world!:
?1 2 3 4 5 6 7 8 9 10 11 | 'use strict' ; var http = require( 'http' ); // 导入http模块 // 创建http server,并传入回调函数。回调函数接收request和response对象 var server = http.createServer( function (request, response){ console.log(request.method + ': ' + request.url); // 获得HTTP请求的method和url: response.writeHead(200, { 'Content-Type' : 'text/html' }); // 将HTTP响应200写入response, 同时设置Content-Type: text/html response.end( '<h1>Hello world!</h1>' ); }); // 将HTTP响应的HTML内容写入response server.listen(8080); // 让服务器监听8080端口 console.log( 'Server is running at http://127.0.0.1:8080/' ); |
在命令提示符下运行该程序,可以看到以下输出:
$ node hello.js Server is running at http://127.0.0.1:8080/
不要关闭命令提示符,直接打开浏览器输入http://localhost:8080,即可看到服务器响应的内容:
同时,在命令提示符窗口,可以看到程序打印的请求信息:
GET: /
GET: /favicon.ico
这就是我们编写的第一个HTTP服务器程序!
让我们继续扩展一下上面的Web程序。我们可以设定一个目录,然后让Web程序变成一个文件服务器。要实现这一点,我们只需要解析request.url中的路径,然后在本地找到对应的文件,把文件内容发送出去就可以了。
解析URL需要用到Node.js提供的url模块,它使用起来非常简单,通过parse()将一个字符串解析为一个Url对象:
?1 2 3 4 | 'use strict' ; var url = require( 'url' ); console.log(url.parse( 'http://user:pass@host.com:8080/path/to/file?query=string#hash' )); |
结果如下:
Url { protocol: 'http:', slashes: true, auth: 'user:pass', host: 'host.com:8080', port: '8080', hostname: 'host.com', hash: '#hash', search: '?query=string', query: 'query=string', pathname: '/path/to/file', path: '/path/to/file?query=string', href: 'http://user:pass@host.com:8080/path/to/file?query=string#hash' }
处理本地文件目录需要使用Node.js提供的path模块,它可以方便地构造目录:
?1 2 3 4 | 'use strict' ; var path = require( 'path' ); var workDir = path.resolve( '.' ); // 解析当前目录('/Users/michael') var filePath = path.join(workDir, 'pub' , 'index.html' ); // 组合完整的文件路径:当前目录+'pub'+'index.html'('/Users/michael/pub/index.html') |
使用path模块可以正确处理操作系统相关的文件路径。在Windows系统下,返回的路径类似于C:\Users\michael\static\index.html,这样,我们就不关心怎么拼接路径了。
最后,我们实现一个文件服务器file_server.js:
?1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 | 'use strict' ; var fs = require( 'fs' ),url = require( 'url' ),path = require( 'path' ),http = require( 'http' ); var root = path.resolve(process.argv[2] || '.' ); // 从命令行参数获取root目录,默认是当前目录 console.log( 'Static root dir: ' + root); var server = http.createServer( function (request, response){ // 创建服务器 var pathname = url.parse(request.url).pathname; // 获得URL的path,类似 '/css/bootstrap.css' var filepath = path.join(root, pathname); // 获得对应的本地文件路径,类似 '/srv/www/css/bootstrap.css' fs.stat(filepath, function (err, stats) { if (!err && stats.isFile()) { // 获取文件状态 console.log( '200 ' + request.url); // 没有出错并且文件存在 response.writeHead(200); // 发送200响应 // 将文件流导向response: fs.createReadStream(filepath).pipe(response); } else { console.log( '404 ' + request.url); // 出错了或者文件不存在 response.writeHead(404); response.end( '404 Not Found' ); } }); }); // 发送404响应 server.listen(8080); console.log( 'Server is running at http://127.0.0.1:8080/' ); |
没有必要手动读取文件内容。由于response对象本身是一个Writable Stream,直接用pipe()方法就实现了自动读取文件内容并输出到HTTP响应。
在命令行运行node file_server.js /path/to/dir,把/path/to/dir改成你本地的一个有效的目录,然后在浏览器中输入http://localhost:8080/index.html:
只要当前目录下存在文件index.html,服务器就可以把文件内容发送给浏览器。观察控制台输出:
200 /index.html
200 /css/uikit.min.css
200 /js/jquery.min.js
200 /fonts/fontawesome-webfont.woff2
第一个请求是浏览器请求index.html页面,后续请求是浏览器解析HTML后发送的其它资源请求。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
Vue为我们提供了很多高级特性,学习和掌握它们有助于提高你的代码水平
如何理解JS作用域的作用是什么呢??今天来给大家说说看js中静态作用域有什么用处的相关内容,小编觉得这篇文章不错,所以分享给大家。
utf8编码算法是什么样的,如何实现?小编这就来给大家分析分析下,对此感兴趣的话可以看看以下知识点,有需要的朋友一定不要错过了。
本篇文章给大家带来了关于JavaScript的相关知识,其中主要介绍了关于字符串对象的相关问题,包括了一些基本概念和实际使用等等内容,下面一起来看一下,希望对大家有帮助。
1.获取Get请求中url的参数:consturlib=require("url");//http:///www.web.com/Login?name=111&pass=222router.get('/Login',function(req,res,next){varmyObj=urlib.parse(req.url,true);
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008