Nodejs编写接口
创始人
2024-01-30 00:06:45
0

编写接口

1.自定义路由模块

const express=require('express')
const router=express.Router()// 挂载对应的路由
router.get('/get',(req,res)=>{// 通过req.query获取客户端通过查询字符串,发送到服务器的数据const query=req.query// 调用res.send()方法,向客户端响应处理的结果res.send({status:0,    // 0表示处理成功,1表示处理失败msg:'GET 请求成功',    //状态的描述data:query // 需要响应给客户端的数据 })
})// 定义post接口
router.post('/post',(req,res)=>{//通过req.body获取请求体中包含的url-encoded格式的数据const body=req.body//调用res.send()向客户端响应结果res.send({status:0,msg:'post 请求成功',   data:body})
})module.exports=router

2.将路由注册到服务器实例上

1.并且引入cors中间件注册到服务器实例上,解决跨域问题
2.将自定义路由模块挂载到服务器上,/api请求
3.express.urlencoded({extends:false} 解析表单中间件

// 导入express
const express=require('express')
// 创建服务实例
const app=express()// 配置解析表单数据的中间件
app.use(express.urlencoded({extends:false}))// 一定要在路由之前,配置cors这个中间件,从而解决接口跨域问题
const cors=require('cors')
app.use(cors)// 导入路由模块
const router=require('./02_apiRouter')
// 把路由模块,注册到app上
app.use('/api',router)// 启动服务器
app.listen(8080,()=>{console.log('Express server running st http://127.0.0.1:8080');
})

测试接口跨域问题

在导入路由模块前,将cors中间件注册到服务器实例上

// 导入express
const express=require('express')
// 创建服务实例
const app=express()// 配置解析表单数据的中间件
app.use(express.urlencoded({extends:false}))// 一定要在路由之前,配置cors这个中间件,从而解决接口跨域问题
const cors=require('cors')
app.use(cors)// 导入路由模块
const router=require('./02_apiRouter')
// 把路由模块,注册到app上
app.use('/api',router)// 启动服务器
app.listen(8080,()=>{console.log('Express server running st http://127.0.0.1:8080');
})

cors介绍:

在这里插入图片描述
在这里插入图片描述

使用express写接口

CORS响应头

1.Access-Control-Allow-Origin

允许那些网站能够请求
在这里插入图片描述

2.限制客户端发送过来的请求头:Access-Control-Allow-Headers
客户端发送请求过来,不能发送额外的请求头信息,因为CORS设定好了,除非在服务端对 Access-Control-Allow-Headers 进行声明
在这里插入图片描述
3.限制请求方式:Access-Control-Allow-Methods

在这里插入图片描述
4.简单请求
在这里插入图片描述
5.预检请求
就是对CORS默认的放行资源之外的请求就叫预检请求
在这里插入图片描述在这里插图片预检请求描述

简单请求和预检请求的区别

在这里插入图片描述

JSONNP接口

1.概念:

JSONP是一个跨域解决方案,目的是跨域请求JSON数据,因为JSON数据是不能跨域请求的,但是我们js跨域请求js脚本是可以的,可以把数据封装成一个js语句,做一个方法的调用。跨域请求js脚本即可获取数据

    1. 标签script的src属性是可以跨域的,所以我们跨域的服务器只要写成调用本地的函数,回调数据就可以实现跨域了
    1. 过我们发现,web页面调用js文件则不受跨域的影响(不仅如此,我们还发现凡是拥有“src”这个属性的标签都拥有跨域的能力,比如<\script>、<\img>、<\iframe>)
    1. 恰巧我们知道有一种叫做JSON的纯字符数据格式可以简洁的描述复杂数据,更妙的是JSON还被js原生支持,所以在客户端几乎可以随心所欲的处理这种格式的数据。
      在这里插入图片描述

在这里插入图片描述
注意事项:
在这里插入图片描述
2.实践,实现JSONP接口的步骤:

在这里插入图片描述
在这里插入图片描述
代码:

// 导入express
const express=require('express')
// 创建服务实例
const app=express()// 配置解析表单数据的中间件
app.use(express.urlencoded({extends:false}))// 配置json接口(必须在配置cors中间件前配置jsonp接口)
app.get('/api/jsonp',(req,res)=>{
//   1.得到回调函数的名称
const funcName=req.query.callback //   2.定义要发送到客户端的数据对象(回调的数据)
const data={ name: 'zs', age: 22 }
//   3.拼接出函数调用的字符串(请求的名称+数据)
const scriptStr = `${funcName}(${JSON.stringify(data)})`
//   4.把拼接的字符串响应给客户端res.send(scriptStr)
})// 一定要在路由之前,配置cors这个中间件,从而解决接口跨域问题
const cors=require('cors')
app.use(cors)// 导入路由模块
const router=require('./02_apiRouter')
// 把路由模块,注册到app上
app.use('/api',router)// 启动服务器
app.listen(8080,()=>{console.log('Express server running st http://127.0.0.1:8080');
})

网页:



Document



测试发现得到回调后服务端所发来的数据
在这里插入图片描述

相关内容

热门资讯

盘点当下最赚钱的无本创业小项目... 创业可以说是现在非常受欢迎的话题,很多人都会想要去创业,去实现自己的梦想,或者说是想改变一下自己的生...
适合小区创业的小本项目有哪些 ... 适合小区创业的小本项目有哪些?创业是每个人都想干的一件事,但是又不知到从何做起,大型的加盟项目投资费...
小区里的小本暴利项目哪些 有哪... 受到疫情影响,今年从年初开始,经济大环境就不算好。大家都在抱怨现在挣钱太难了,市场不景气,都没什么生...
千元小本创业有哪些 2018年... 经济形势的发展下,人民币逐渐贬值。对于创业者来说,想要找到1000元以下创业项目是比较困难的。因为一...
适合小本创业的五个好项目 推荐... 二胎政策开放很久了,儿童行业是具有潜力的市场,现在的家长都很疼爱自己的孩子,很注重孩子的早期教育培训...
2020年最好的创业项目是什么...   还不知道朋友看这里那今天我们就来说几个创业的好项目给大家分享:1、开宠物店,现在的年轻人压力大,...
小本创业代理好项目 小本创业代...  短视频,自媒体,达人种草一站服务最新移动电商创业项目:手机微信制作平台照片书照片书就是把您手机里的...
在四五线小城市有哪些城镇小本创... 如今的生活越来越好,每个人对美好生活的留念越来越重视了,很多人在生活中不管遇到什么样的事情,只要是值...
2019小本创业项目哪个比较好... 现在这些传统行业竞争压力大,投入成本也越来越高了。想要创业但是条件又有限,怎样才能以最小的成本去努力...
投入一千多 有必要理财吗 投入... 摘要:项目:防晒帽子、配饰作为一个赚女人钱的项目,卖防晒帽及配饰还是很不错的。有多少女性朋友,惧怕炎...