当前位置:   article > 正文

通过node.js来写接口_node写接口

node写接口

如果要通过node.js来写接口的话,首先我们需要借助一个框架--express,这个框架可以帮助我们快速的创建web服务器,所以我们需要通过npm下载这个包。

express写get接口

  1. // 引入express
  2. const express = require('express')
  3. // 调用express()
  4. const app = express()
  5. // 设置请求对应的处理函数--当客户端以get方法请求,
  6. //请求地址后面需要加/getbooks才能访问到响应后的数据
  7. //app.get('/getbooks')相当于添加事件监听,当用户以get方法请求时,地址后面需要跟/getbooks,后面的回调函数才会执行
  8. app.get('/getbooks', function (request, response) {
  9. let books = {
  10. "status": 200,
  11. "msg": "获取图书列表成功",
  12. "data": [
  13. {
  14. "id": 1,
  15. "bookname": "西游记",
  16. "author": "吴承恩",
  17. "publisher": "北京图书出版社"
  18. },
  19. {
  20. "id": 2,
  21. "bookname": "红楼梦",
  22. "author": "曹雪芹",
  23. "publisher": "上海图书出版社"
  24. },
  25. {
  26. "id": 3,
  27. "bookname": "三国演义",
  28. "author": "罗贯中",
  29. "publisher": "北京图书出版社"
  30. }
  31. ]
  32. }
  33. //response.send是express框架提供的方法,相当于结束本次请求。
  34. response.send(books)
  35. })
  36. // 监听端口,启动web服务
  37. app.listen(8000, function () {
  38. console.log('app listening on port 8000!')
  39. })

通过localhost:8000/getbooks成为访问到数据。

此上,我们便简单的实现了一个get请求来获取到接口的数据。

express写post接口--键值对参数

当请求头中的content-type为x-www-form-urlencoded时,表示上传的为普通键值对参数

  1. // 引入express
  2. const express = require('express')
  3. // 调用express()
  4. const app = express()
  5. // 使用中间件--请求的格式为普通键值对格式
  6. app.use(express.urlencoded())
  7. // 接口2--post普通键值对格式a=1&b=2
  8. app.post('/addbooks', (request, response) => {
  9. //request.body发送的请求的参数
  10. console.log('请求返回', request.body)
  11. //response.send响应回来的参数
  12. response.send({ a: 1 })
  13. })

因为这里我们是通过post请求传递参数的,所以这里我们不能继续向上面的get请求一样通过地址栏测试了,这里我会借助一个测试接口的工具来进行测试,用到的工具是--apifox。

这里我们直接发送请求,我们会向后端发送两个参数,下面是得到响应后的参数

我们去到小黑窗可以看见发送来的请求参数

express写post接口--json格式的参数

  1. // 引入express
  2. const express = require('express')
  3. // 调用express()
  4. const app = express()
  5. // 会自动加入req.body属性,这个属性中就包含了post请求所传入的参数,格式为json格式
  6. app.use(express.json())
  7. // 接口3--post-json格式
  8. app.post('/add-json', (request, response) => {
  9. console.log('请求返回', request.body)
  10. response.send({ "name": "xxx" })
  11. })

这里我们依旧会加入一个中间件来得到请求的参数。

测试接口

express写post接口--form-data文件上传

  1. // 引入express
  2. const express = require('express')
  3. // 调用express()
  4. const app = express()
  5. // 引入包
  6. const multer = require('multer');
  7. // 配置
  8. // uploads表示一个目录名,你也可以设置成其它的
  9. const upload = multer({ dest: 'uploads/' }) // 上传的文件会保存在这个目录下
  10. // 接口4--通过post请求进行文件的上传
  11. app.post('/add-file', upload.single('img'), (request, response) => {
  12. console.log(request.body)
  13. console.log(request.file)
  14. response.send({ name: "小红" })
  15. })

测试接口

响应的参数

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/盐析白兔/article/detail/69006
推荐阅读
相关标签
  

闽ICP备14008679号