jsonp数据

古老的跨域方法,已经逐步被CORS淘汰,但对后台来说,就是一个GET请求而已。民间标准。
缺点:对权限松散,安全性差。
CORS是ajax的增强,

普通ajax通过监听onredyStatusChange来控制是否完成。

jsonp的连接样子:
http://localhost:8080/a?n1=15&n2=77&cb
=>show(92)
服务端代码:

const Koa = require("koa");
const Router = require("koa-router");
const static = require("koa-static");
const opn = require("opn");

let router = new Router();
let server = new Koa();
server.listen(8000);


router.get('/a', async ctx=>{
    let {n1, n2, cb} = ctx.query;
    n1 = parseInt(n1);
    n2 = parseInt(n2);
    ctx.body=`${cb}(${n1 + n2})`;
})
server.use(router.routes());
// static
server.use(static('./static'));

opn("http://localhost:8000/a?n1=15&n2=77&cb=show")

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

<!DOCTYPE html>
<html lang="zh">
<head>
    <meta charset="UTF-8">
    <title>jsonp跨域</title>
</head>
<body>
    <script src="http://code.jquery.com/jquery-3.4.1.js"></script>
    <script>
        (async ()=>{
            let data = await $.ajax({
                url: 'http://localhost:8000/a',
                dataType: 'jsonp',
                data: {
                    n1:80,
                    n2: 19
                },
                jsonp: 'cb'
            })
            alert(data);
        })();
    </script>
</body>
</html>

在这里插入图片描述
跨域成功。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值