转自:https://www.cnblogs.com/gamedaybyday/p/6637933.html

仅用于学习!!!

目录:

一 express框架接收

二 接收Get

三 发送Get

四 接收Post

五 发送Post

一 express框架接收

1

2

3

4

5

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:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

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);

浏览器打开:

1

http://127.0.0.1:3000/?url=123&name=321

网页显示:

1

2

网站名:321

网站 URL:123

三 发送Get

index.js:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

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:

1

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

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'});

1

2

3

4

5

6

7

8

9

10

        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:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

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-urlencoded',

        '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();

NodeJS收发GET和POST请求相关推荐

  1. [NodeJS] Jest 环境下 Axios 请求报错: Cross origin http://localhost forbidden

    文章目录 问题概述 解决方案 参考 本博客站点已全量迁移至 DevDengChao 的博客 https://blog.dengchao.fun , 后续的新内容将优先在自建博客站进行发布, 欢迎大家访 ...

  2. 【SSM+ElementUI】综合练习-Axios Mock EasyMock nodejs npm webpack vuecli restful 请求

    SSM+ElementUI综合练习-day01 一.课程介绍 前后端分离开发(概念熟悉) 搭建前端环境-nodejs&npm&vue&webpack&vuecli(了解 ...

  3. expressjs路由和Nodejs服务器端发送REST请求 - - ITeye博客

    Nodejs创建自己的server后,我们如果需要从客户端利用ajax调用别的服务器端的数据API的接口,这时候出现了ajax跨域问题. 一种是利用在客户端解决跨域问题  这种方案大家可以去网上查查 ...

  4. nodejs+Koa2实现小程序的微信支付请求(一)

    nodejs+koa2 实现微信支付请求 在开发之前我们先看一下小程序向微信请求支付的业务流程 第一步,小程序先发起支付请求 小程序首先先向"商家系统后台"发起请求支付,也就是我们 ...

  5. 简单总结nodejs处理tcp连接的核心流程

    这篇文章主要介绍了nodejs处理tcp连接的核心流程,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下 前几天和一个小伙伴交流了一下nodejs中 ...

  6. nodejs request module里的json参数的一个坑

    今天工作的时候遇到一个坑,在客户端用nodejs给服务器发送HTTP请求,服务器老是报错:In the context of Data Services an unknown internal ser ...

  7. nodejs 更新_NodeJs(一)我对NodeJs的认知

    欢迎来到我的NodeJs专题系列,更多精彩内容持续更新中,敬请关注! 写在前面 前面我已经分享了100+篇前端相关的技术文章,都是自己平时工作中遇到的一些问题的问题,还有是我平时自学的内容.但是那些前 ...

  8. 76.Nodejs Express目录结构

    转自:https://blog.csdn.net/xiaoxiaoqiye/article/details/51160262 Express是一个基于Node.js平台的极简.灵活的web应用开发框架 ...

  9. get和post方式请求数据,jsonp

    get方式请求数据: var theurl = "http://c.m.163.com/nc/article/headline/T1348647853363/0-140.html" ...

  10. NodeJS服务器退出:完成任务,优雅退出

    上一篇文章,我们通过一个简单的例子,学习了NodeJS中对客户端的请求(request)对象的解析和处理,整个文件共享的功能已经完成.但是,纵观整个过程,还有两个地方明显需要改进: 首先,不能共享完毕 ...

最新文章

  1. 使用淘宝镜像cnpm安装Vue.js
  2. Worksheet.get_Range Method
  3. python3精要(45)-exit
  4. linux 手动配置ip地址方法
  5. jsp无法解析java方法_Spring无法解析JSP视图
  6. 深度学习-Tensorflow2.2-批标准化简介-14
  7. JS数组的需要注意的问题
  8. OpenGL坐标系及基本变换
  9. 2022年,图机器学习Graph ML发展到哪了?
  10. python的类与继承
  11. python编写代码自动运行程序_利用Python编写自动打开指定软件的程序
  12. Android6.0之AMS启动
  13. html+table表头固定,HTML table固定表头,htmltable固定表分享
  14. 项目管理中成本管理相关指标
  15. 底层码农的Stanford梦 --- 从SCPD开始 [转]
  16. JAVA小记3(第三周)
  17. 运行Springboot项目时报错WhiteLabel Error Page
  18. 计算机专业在职研究生排名,计算机专业在职研究生学校排名
  19. 腾讯天美测开一面面经
  20. 浪花一朵朵 吉他简谱

热门文章

  1. 使用soap遇到的缓存问题
  2. 写在2017年的总结
  3. 电商网站交易记录设计
  4. hadoop重新启动之后Datanode无法启动的问题
  5. JavaScript--如何插入JS
  6. 关于嵌套类的调用更新问题
  7. 如何卸载密码保护的Symantec Endpoint Protection
  8. python实训day7
  9. Linux文本三剑客超详细教程---grep、sed、awk
  10. socketserver 模块的构成