位置: IT常识 - 正文

🎉使用JSONP解决跨域(jsoncpp使用)

编辑:rootadmin
1.首先需要知道什么是跨域 浏览器从一个域名的网页去请求另一个域名的资源时,域名、端口、协议任一不同,都是跨域 出于浏览器的同源策略限制 同源策略(Sameoriginpolicy)是一种约定,它是浏览器最核心也最基本的安全功能,如果缺少了同 源策略,则浏览器的正常功能可能都会受到影响 同源策略限制 ... 1.首先需要知道什么是跨域浏览器从一个域名的网页去请求另一个域名的资源时,域名、端口、协议任一不同,都是跨域

推荐整理分享🎉使用JSONP解决跨域(jsoncpp使用),希望有所帮助,仅作参考,欢迎阅读内容。

🎉使用JSONP解决跨域(jsoncpp使用)

文章相关热门搜索词:json用法示例理解,如何使用json,json用法,json的使用场景,json的使用场景,json使用教程,如何使用json,json使用教程,内容如对您有帮助,希望把文章链接给更多的朋友!

出于浏览器的同源策略限制

同源策略(Sameoriginpolicy)是一种约定,它是浏览器最核心也最基本的安全功能,如果缺少了同 源策略,则浏览器的正常功能可能都会受到影响同源策略限制内容有:

Cookie、LocalStorage、IndexedDB 等存储性内容DOM 节点AJAX 请求发送后,结果被浏览器拦截了2.什么是JSONPJSONP是JSON with Padding的略称,JSONP为民间提出的一种跨域解决方案,通过客户端的script标签发出的请求方式原理就是通过添加一个<script>标签,向服务器请求JSON数据,这样不受同源政策限制。服务器收到请求后,将数据放在一个callback回调函数中传回来。比如axios。不过只支持GET请求且不安全,可能遇到XSS攻击,不过它的好处是可以向老浏览器或不支持CORS的网站请求数据服务端: 将服务端返回数据封装到指定函数中返回 callback({返回数据})客户端: 不管是我们的script标签的src还是img标签的src,或者说link标签的href他们没有被同源策略所限制,比如我们有可能使用一个网络上的图片,就可以请求得到;所以利用同源策略漏洞,将访问地址放在下面的标签的路径中,<script src="https://www.cnblogs.com/Lucky-daisy/p/www.baidu.com"> 、< img src=""/>、 <link href=""/> 来解决跨域的问题3.JSONP简单实现

node服务器端代码

const express = require('express')const app = express()const port = 3000//路由配置app.get("/user",(req,res)=>{//1.获取客户端发送过来的回调函数的名字let fnName = req.query.callback;//2.得到要通过JSONP形式发送给客户端的数据const data = {name:'tom'}//3.根据前两步得到的数据,拼接出个函数调用的字符串let result = `${fnName}({name:"tom"})`//4.把上步拼接得到的字符串,响应给客户端的<script> 标签进行解析执行res.send(result);})app.listen(port, () => {console.log(`Example app listening on port ${port}`)})

前端代码

<head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>JSONP简单实现</title></head><body><button id="btn">点击发送请求</button><script>function getJsonpData(data) {console.log("获取数据成功")console.log(data) //{name:'tom'}}var btn = document.getElementById("btn");btn.onclick = function () {//创建script标签var script = document.createElement("script");script.src = 'http://localhost:3000/user?callback=getJsonpData';document.body.appendChild(script);script.onload = function () {document.body.removeChild(script)}}</script></body></html>4.结论优点:

兼容性比较好,可用于解决主流浏览器的跨域数据访问的问题不受到同源策略的限制,在请求完毕后可以通过调用 callback 的方式回传结果缺点:

仅支持get请求;具有局限性,不安全,可能会受到XSS攻击;只支持跨域 HTTP 请求这种情况,不能解决不同域的两个页面之间如何进行 Javascript 调用的问题
本文链接地址:https://www.jiuchutong.com/zhishi/313076.html 转载请保留说明!

上一篇:帝国cms实现会员注册之后根据所在会员组转向的方法(帝国cms会员发布信息数量)

下一篇:python A*算法是什么(python apriori算法)

  • 社保基数申报怎么看是否成功
  • 建筑行业一般纳税人增值税税率是多少
  • 广告制作赚钱吗?
  • 销售补差怎么做分析
  • 外贸企业出口销售通常采用
  • 在计算缴纳房产税时,不计入房产原值的是
  • 我公司给对方公司付款
  • 固定资产怎么盘点
  • 销售业务中的贴息如何开票?
  • 出口退税进项抵扣了不退税可以吗
  • 不符合规定(未带编码或编码选择错误)的发票,纳税人该怎么做?
  • 维修材料属于什么会计科目
  • 简易计税视同销售如何处理?
  • 计提工资大于实发工资
  • 增值税销售额怎么看
  • win7系统中英文切换快捷键
  • 个体工商户年检怎么办
  • 暂时性差异的转回期间如何确定
  • 如何禁用开始目录的app自动推荐
  • linux c gui
  • Win11错误提示"the pc must support secure boot"怎么解决
  • 关于笔记本电脑的文案
  • 实缴注册资本股权转让怎么交税
  • 环形链表入口节点
  • php初学
  • 低值易耗品的三级科目有哪些
  • node与nodejs
  • 关系代数关系运算
  • codeigniter 教程
  • python random random
  • vue虚拟domdiff算法
  • python 微信
  • c语言中fopen函数的头文件
  • 结算备付金管理办法(2019年修订版)
  • 当月确认收入可以下月确认成本吗
  • mongodb document
  • 现金短缺或溢余指的是什么
  • 现金流量表编制格式
  • 预提费用取消了吗
  • 社保缴费基数和医保缴费基数一样吗
  • 出差会计处理
  • 应收账款余额在借方还是贷方
  • 免抵退税和留抵退税计算题
  • 有限合伙企业的
  • 为什么出口退税是贷方
  • 支付设备款怎么做账
  • 培训学校预收学费可退吗
  • 一般纳税人采购分录
  • 固定资产能直接计入费用吗为什么
  • 忘记报关可以补报吗
  • 购置固定资产的预算是财务预算吗
  • 应交个人所得税借方余额表示什么
  • 离岸服务外包收入
  • 发票已开后 对方公司名称变更怎么处理?
  • 会计凭证装订时间法律规定
  • 销售自己使用过的物品免税吗
  • sql server 错误
  • 收集整理的近义词
  • apple watch手表怎么看型号
  • win10升级20h
  • 苹果怎样快速移动应用到其他桌面
  • pssvc.exe - pssvc是什么进程 有什么用
  • win10如何恢复已删除的密钥
  • win8怎么关闭系统自动更新
  • centos 安装
  • 如何禁用u盘启动项
  • WIN10安装介质不识别硬盘
  • Win10手机版校
  • jquery animate源码
  • javascript+css3开发打气球小游戏完整代码
  • js class属性
  • 学javascript的书
  • 正途科技有限公司
  • unity vtext
  • 高铁票抵扣进项能抵扣吗
  • 江苏国家电子税务局新版本怎么申领发票
  • 上海税务ca证书更新
  • 天府新区劳动局投诉电话
  • 上海房屋出租交税
  • 网上缴费后如何复电
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设