使用nodejs实现jsonp跨域请求

使用nodejs实现jsonp

前言

昨天在工作中第一次使用ajax的jsonp跨域请求数据,但是遇到了Uncaught SyntaxError: Unexpected identifier这个问题,上网查解释如下:
在这里插入图片描述
出现这种错误的情况之一确实是图中所说的,但是我这个出现的原因其实是后台返回的数据格式有问题,双括号里又套了一层双括号,导致前台解析的时候出了错。好了,问题解决了,但是心中还有一些疑问,jsonp到底是如何实现跨域的呢?

jsonp实现跨域的流程

废话少说,直接上代码解释:
1、服务端代码jsonp.js

let express=require('express')
let app=express()
app.get('/',(req,res)=>{
    let fn=req.query.callback  //fn='zl'
    let data=JSON.stringify({
        data:"hahaha"
    })
    res.end(fn+`(${data})`)
})
app.listen(80,()=>{
    console.log('serve is running...')
})

2、客户端请求:


```html
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script src="../../node_modules/jquery/dist/jquery.js"></script>
</head>
<body>
    <script type="text/javascript">
        function zl(res){
            console.log(res) //输出:{data:"hahaha"}
        }
    </script>
    <script src="http://localhost:80/?callback=zl"></script>
</body>
</html>

执行过程如下:
1、<script src="http://localhost:80/?callback=zl"></script>发送请求
2、服务端收到请求let fn=req.query.callback此时fn的值就是’zl’
3、服务端向客户端返回数据,经过字符串拼接,返回给客户端的其实是zl({data:“hahaha”})
4、客户端收到服务端返回的内容:zl({data:“hahaha”})
5、客户端将zl({data:“hahaha”})解析为调用了zl函数且入参为{data:“hahaha”},所以最终客户端打印了{data:“hahaha”}
综上,其实jsonp的原理很简单,就是利用了script标签可以跨域请求这一特点,前端把方法作为参数传到服务端,然后服务端将数据作为方法的入参返回给前端,这样就能实现前后端通信。

扩展

使用ajax跨域:

$.ajax({
    type: "GET",
    url: "http://localhost:80/",
    dataType: "jsonp",//  
    jsonp: "callback",//此参数的值与服务器端的req.query.callback对应
    success: function (data) {
        console.log(data)//输出:{data:"hahaha"}
    },
    error: function (err) {
        console.log(err)
        console.log('请求错误')
    }
});
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值