我们专注攀枝花网站设计 攀枝花网站制作 攀枝花网站建设
成都网站建设公司服务热线:400-028-6601

网站建设知识

十年网站开发经验 + 多家企业客户 + 靠谱的建站团队

量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决

nodejs库express是怎么接收inboundjson请求的-创新互联

这篇文章主要介绍“nodejs库express是怎么接收inbound json请求的”,在日常操作中,相信很多人在nodejs库express是怎么接收inbound json请求的问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”nodejs库express是怎么接收inbound json请求的”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

创新互联:2013年至今为各行业开拓出企业自己的“网站建设”服务,为上千余家公司企业提供了专业的成都做网站、成都网站设计、网页设计和网站推广服务, 按需定制设计由设计师亲自精心设计,设计的效果完全按照客户的要求,并适当的提出合理的建议,拥有的视觉效果,策划师分析客户的同行竞争对手,根据客户的实际情况给出合理的网站构架,制作客户同行业具有领先地位的。

这样几行简单的代码创建一个web服务器:

var express = require('express');var app = express();var server = require('http').Server(app);var bodyParser = require('body-parser');app.use(bodyParser.json({limit: '10mb', extended: true}));

然后使用app.post("/getSimilarImage", function(req, res){
// 此处编写业务逻辑
});

就可以接收json请求了。问题就是,我通过postman发送的json字符串,是如何被nodejs的express库处理的呢?

调试一下,trim_prefix的参数path即我在postman里测试的API endpoint:

nodejs库express是怎么接收inbound json请求的

调用layer的handle_request方法,这个很像SAP ABAP里的IF_HTTP_EXTENSION的HANDLE_REQUEST方法。

nodejs库express是怎么接收inbound json请求的

express中的中间件,query.js:

nodejs库express是怎么接收inbound json请求的

这个中间件里也用了直接和undefined做比较的方式:

nodejs库express是怎么接收inbound json请求的

这里准备开始读取inbound json了:

nodejs库express是怎么接收inbound json请求的

nodejs库express是怎么接收inbound json请求的

通过stream上注册的回调函数onData进行数据读取:
读取了65018个字节的数据:

nodejs库express是怎么接收inbound json请求的

把读取的数据写到buffer里:

nodejs库express是怎么接收inbound json请求的

写的同时还被第252行的decoder进行了解码:

nodejs库express是怎么接收inbound json请求的

当inbound message的数据全部读取完毕后,触发End事件,执行注册的回调done函数:

nodejs库express是怎么接收inbound json请求的

此时所有读取的数据都存放在变量body里了:

nodejs库express是怎么接收inbound json请求的

这个json.js负责把body变量里包含的字符串解析成json对象:

nodejs库express是怎么接收inbound json请求的

由此可见,body-parser这个库最终使用的仍然是原生的JSON.parse API来完成解析任务。

nodejs库express是怎么接收inbound json请求的

到此,关于“nodejs库express是怎么接收inbound json请求的”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注创新互联-成都网站建设公司网站,小编会继续努力为大家带来更多实用的文章!


文章题目:nodejs库express是怎么接收inboundjson请求的-创新互联
网页网址:http://shouzuofang.com/article/ijeeh.html

其他资讯