首页 > 编程 > JavaScript > 正文

NodeJS收发GET和POST请求的示例代码

2019-11-19 15:40:31
字体:
来源:转载
供稿:网友

本文介绍了NodeJS收发GET和POST请求的示例代码,分享给大家,也给自己留个笔记

一 express框架接收

app.get('/',function(req,res) {  var url = req.query.url;  var name = req.query.name;  console.log(url, name);}); 

二 接收Get

1. get参数在req.url上

2. 使用url.parse将数据由字符串转变为obj

index.js:

var http = require('http');var url = require('url');var util = require('util'); //req 请求信息  res返回信息http.createServer(function(req, res){  res.writeHeader(200, {'Content-Type':'text/javascript;charset=UTF-8'}); //状态码+响应头属性   // 解析 url 参数  var params = url.parse(req.url, true).query; //parse将字符串转成对象,req.url="/?url=123&name=321",true表示params是{url:"123",name:"321"},false表示params是url=123&name=321  res.write("网站名:" + params.name);  res.write("/n");  res.write("网站 URL:" + params.url);  res.end(); }).listen(3000); 

浏览器打开:http://127.0.0.1:3000/?url=123&name=321

网页显示:

网站名:321

网站 URL:123

三 发送Get

index.js:

var http = require('http');   var qs = require('querystring');   var data = {   a: 123,   time: new Date().getTime()};//这是需要提交的数据     var content = qs.stringify(data);   var options = {   hostname: '127.0.0.1',   port: 10086,   path: '/pay/pay_callback?' + content,   method: 'GET' };   var req = http.request(options, function (res) {   console.log('STATUS: ' + res.statusCode);   console.log('HEADERS: ' + JSON.stringify(res.headers));   res.setEncoding('utf8');   res.on('data', function (chunk) {     console.log('BODY: ' + chunk);   }); });   req.on('error', function (e) {   console.log('problem with request: ' + e.message); });   req.end(); 

四 接收Post

 当请求这个页面时,如果post数据中没有name和url,则返回一个提交页面;如果有name和url,则打印。

1. post请求会触发"data"事件。

2. chuck使用+=保存,因为会额外请求favicon.ico,导致body={}。

3. 请求结束,会触发"end"事件。将chuck反序列化querystring.parse(body)为对象数组, 使用body.name访问post变量。

index.js:

var http = require('http');var querystring = require('querystring'); var postHTML =  '<html><head><meta charset="utf-8"><title>菜鸟教程 Node.js 实例</title></head>' +  '<body>' +  '<form method="post">' +  '网站名: <input name="name"><br>' +  '网站 URL: <input name="url"><br>' +  '<input type="submit">' +  '</form>' +  '</body></html>'; http.createServer(function (req, res) {  //暂存请求体信息  var body = "";   //请求链接  console.log(req.url);   //每当接收到请求体数据,累加到post中  req.on('data', function (chunk) {    body += chunk; //一定要使用+=,如果body=chunk,因为请求favicon.ico,body会等于{}    console.log("chunk:",chunk);  });   //在end事件触发后,通过querystring.parse将post解析为真正的POST请求格式,然后向客户端返回。  req.on('end', function () {    // 解析参数    body = querystring.parse(body); //将一个字符串反序列化为一个对象    console.log("body:",body);    // 设置响应头部信息及编码/<br><br>   res.writeHead(200, {'Content-Type': 'text/html; charset=utf8'});      if(body.name && body.url) { // 输出提交的数据      res.write("网站名:" + body.name);      res.write("<br>");      res.write("网站 URL:" + body.url);    } else { // 输出表单      res.write(postHTML);    }    res.end();  });}).listen(3000); 

浏览器中打开:http://127.0.0.1:3000/

第一次访问127.0.0.1,post中没有name和url,显示提交页面。

点击提交后,网页会打印出如下结果。

问题:

1. req.on("end"事件会多次触发。因为会请求favicon.ico。

2.  res.writeHead(200, {'Content-Type': 'text/html; charset=utf8'});

text/html的意思是将文件的content-type设置为text/html的形式,浏览器在获取到这种文件时会自动调用html的解析器对文件进行相应的处理。

text/plain的意思是将文件设置为纯文本的形式,浏览器在获取到这种文件时并不会对其进行处理。

五 发送Post

index.js:

var http = require('http');var querystring = require('querystring'); var contents = querystring.stringify({  name:'byvoid',  email:'byvoid@byvoid.com',  address:'Zijing'}); var options = {  host:'www.byvoid.com',  path:'/application/node/post.php',  method:'POST',  headers:{    'Content-Type':'application/x-www-form-urlendcoded',    'Content-Length':contents.length  }} var req = http.request(options, function(res){  res.setEncoding('utf8');  res.on('data',function(data){    console.log("data:",data);  //一段html代码  });}); req.write(contents);req.end; 

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持武林网。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表