目前学的比较简单,网址传参没有采用加密方式,我们一般用"?"来对url和参数进行分隔,用&来对每个参数进行分隔,新建了summary.js代码如下
其中,
第6行的常量path就为网址中"?"前的路径内容
第8行的常量query就为网址中"?"后的参数内容
例如localhost:5000/api/blog/list?id=天海一直在&pwd=123456
请求得到的path为:/api/blog/list
请求得到的query为:{ id: '天海一直在', pwd: '123456' }
在引用querystring时发现该方法被划线了,原因是封装的querystring被做了弃用标识,表示后续不会对此封装函数进行更新和维护,过一段时间可能会被删除,这就导致不能正常对url进行切片,这时只需要按住ctrl点击被划掉的querystring,进入js封装的原代码。
将弃用声明这一行删除,ctrl +s保存,这时回到summray.js就可以看到querystring不是被划线的了
这时在该目录下的终端输入运行,打开浏览器,输入网址http://localhost:5000/api/blog/list?id=天海一直在&pwd=123456,就可以实现问号后面的网页参数可以被提取出来的功能了,运行的返回结果如下:
PS D:文件Nodejs学习> node summray.js
server running at port 5000
method GET
url /api/blog/list?id=%E5%A4%A9%E6%B5%B7%E4%B8%80%E7%9B%B4%E5%9C%A8&pwd=123456
path /api/blog/list
query [Object: null prototype] { id: '天海一直在', pwd: '123456' }
2022/3/27后加入内容
实际解决问题借鉴评论区老哥的方法就是将querystring替换为querystringify
先npm i querystringify
再导入:const qs = require('querystringify')
最后使用:const body = qs.parse(str)即可
当用这个方法时出现白线,然后查官方文档有这样一句话:
API 被视为旧版的。 虽然它仍在维护,但是新的代码应该改为使用 <URLSearchParams> API。
然后点进<URLSearchParams> 这个链接。找到了这个:
但有个问题:就是post请求连接所获得的字符串并不是上面URL()中的详细地址 ,就没法用这个方法。
解决:在连接post请求所获得的字符串前面再加上'http://xxxx/?’那个协议也是根据自己的情况而定。
当然,对于这个新的node方法我也是直接复制用的,并没有非常具体看,所以里面东西还是要大家自己在官网看。