从零开始学习Node.js系列教程一:http get和post用法分析

前端之家收集整理的这篇文章主要介绍了从零开始学习Node.js系列教程一:http get和post用法分析前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

本文实例讲述了Node.js中http get和post用法分享给大家供大家参考,具体如下:

httpserverrequestget.js

获取GET请求内容 由于GET请求直接被嵌入在路径中,URL是完整的请求路径,包括了?后面的部分,因此你可以手动解析后面的内容作为GET请求的参数。 node.js中url模块中的parse函数提供了这个功能。 */ var http = require('http'); var url = require('url'); var util = require('util'); http.createServer(function(req,res){ res.writeHead(200,{'Content-Type': 'text/plain'}); res.end(util.inspect(url.parse(req.url,true))); }).listen(3000); //在浏览器中访问http://localhost:3000/user?name=joey&email=joey@joey.com 然后查看返回结果

httpserverrequestpost.js

内容全部的都在请求体中,http.ServerRequest并没有一个属性内容为请求体,原因是等待请求体传输可能是一件耗时的工作, 比如上传文件,而很多时候我们可能并不需要理会请求体的内容,恶意的POST请求会大大消耗服务器的资源,所有node.js默认是不会解析请求体的, 当你需要的时候,需要手动来做。 */ var http = require('http'); var querystring = require('querystring'); var util = require('util'); http.createServer(function(req,res){ var post = ''; //定义了一个post变量,用于暂存请求体的信息 req.on('data',function(chunk){ //通过req的data事件监听函数,每当接受到请求体的数据,就累加到post变量中 post += chunk; }); req.on('end',function(){ //在end事件触发后,通过querystring.parse将post解析为真正的POST请求格式,然后向客户端返回。 post = querystring.parse(post); res.end(util.inspect(post)); }); }).listen(3000);

注意:不要在真正的生产应用中使用上面这种简单的方法获取POST请求,因为它有严重的效率问题和安全问题,这只是一个帮你理解的示例。

知识扩展:util.inherits继承

函数内定义的属性和一个原型中定义的函数,通过util.inherits实现继承 注意,Sub仅仅继承了Base在原型中定义的函数,而构造函数内部创造的base属性和sayHello函数都没有被Sub继承。 */ var util = require('util'); function Base(){ this.name = 'base'; this.base = 1991; this.sayHello = function(){ console.log('Hello ' + this.name); }; } Base.prototype.showName = function(){ console.log(this.name); }; function Sub(){ this.name = 'sub'; } util.inherits(Sub,Base); var objBase = new Base(); objBase.showName(); objBase.sayHello(); console.log(objBase); var objSub = new Sub(); objSub.showName(); //objSub.sayHello(); console.log(objSub);

希望本文所述对大家nodejs程序设计有所帮助。

猜你在找的Node.js相关文章