位置: 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算法)

  • 荣耀magic3怎么设置铃声(荣耀magic3怎么设置通话录音)

    荣耀magic3怎么设置铃声(荣耀magic3怎么设置通话录音)

  • 怎样将电脑备份的聊天记录回复到手机中(怎样将电脑备份传到小米11手机)

    怎样将电脑备份的聊天记录回复到手机中(怎样将电脑备份传到小米11手机)

  • 美团我的钱包在哪?(美团我的钱包在哪里找不到怎么绑定)

    美团我的钱包在哪?(美团我的钱包在哪里找不到怎么绑定)

  • 抖音如何设置定时关闭(抖音如何设置定时关闭直播)

    抖音如何设置定时关闭(抖音如何设置定时关闭直播)

  • 怎么找不到漂流瓶(怎么也找不到漂流瓶从哪里找)

    怎么找不到漂流瓶(怎么也找不到漂流瓶从哪里找)

  • qq视频聊天怎么设置悬浮窗(qq视频聊天怎么放视频)

    qq视频聊天怎么设置悬浮窗(qq视频聊天怎么放视频)

  • 个人热点是干什么的(个人热点let)

    个人热点是干什么的(个人热点let)

  • 手机主板发烫解决方法(手机主板发烫会造成后果)

    手机主板发烫解决方法(手机主板发烫会造成后果)

  • 红米gps的修复教程(红米gps设置在哪里设置)

    红米gps的修复教程(红米gps设置在哪里设置)

  • 通过赞赏码能找到微信吗(通过赞赏码能找到抖音吗)

    通过赞赏码能找到微信吗(通过赞赏码能找到抖音吗)

  • 手机系统崩溃如何修复(手机系统崩溃如何刷机)

    手机系统崩溃如何修复(手机系统崩溃如何刷机)

  • airpods保修要发票吗(airpods保修要带盒子吗)

    airpods保修要发票吗(airpods保修要带盒子吗)

  • ps图层锁定了怎么解锁(ps图层锁定了怎么解开)

    ps图层锁定了怎么解锁(ps图层锁定了怎么解开)

  • 7pios11正式版卡不卡(ip11和ip7卡槽)

    7pios11正式版卡不卡(ip11和ip7卡槽)

  • 微信群发一天限制几条(微信群发一天不能超过多少条信息)

    微信群发一天限制几条(微信群发一天不能超过多少条信息)

  • 索尼金砖和黑砖的区别(索尼金砖和黑砖哪个值得入手)

    索尼金砖和黑砖的区别(索尼金砖和黑砖哪个值得入手)

  • 怎样发朋友圈不被折叠(怎样发朋友圈不需要图片)

    怎样发朋友圈不被折叠(怎样发朋友圈不需要图片)

  • 怎样关闭拼多多省钱月卡功能(怎样关闭拼多多快捷支付)

    怎样关闭拼多多省钱月卡功能(怎样关闭拼多多快捷支付)

  • 手机营业厅怎么领流量(手机营业厅怎么解封电话卡)

    手机营业厅怎么领流量(手机营业厅怎么解封电话卡)

  • 荣耀20i怎么退出程序(荣耀20i怎么退出耳机模式)

    荣耀20i怎么退出程序(荣耀20i怎么退出耳机模式)

  • 美图秀秀拼接长图模糊(美图秀秀拼接长图加文字)

    美图秀秀拼接长图模糊(美图秀秀拼接长图加文字)

  • iPhone怎么同一个ID不推送(苹果手机同一个)

    iPhone怎么同一个ID不推送(苹果手机同一个)

  • gtx1660ti什么级别显卡

    gtx1660ti什么级别显卡

  • 怎样找回私密照片(如何找回私密相册里面照片)

    怎样找回私密照片(如何找回私密相册里面照片)

  • 快手慢放视频怎么制作(快手视频怎样慢放)

    快手慢放视频怎么制作(快手视频怎样慢放)

  • H5网站建设有哪些优势(h5网站有什么优势)

    H5网站建设有哪些优势(h5网站有什么优势)

  • 微信好友来源朋友验证消息(微信 好友来源)

    微信好友来源朋友验证消息(微信 好友来源)

  • Linux GCC常用命令详解(linux gcc命令详解)

    Linux GCC常用命令详解(linux gcc命令详解)

  • 股东撤资涉及到哪些税如何缴纳?
  • 销售分哪几类
  • 本月发生费用下月收到发票
  • 装修费用税法规定
  • 财务报表可以补充分类吗
  • 发票章没盖在盖章处
  • 增值税一般纳税人是什么意思
  • 支付劳务费需要开发票吗
  • 福利企业发放职工集资利息是不是要交个人所得税
  • 建筑行业开工程票,材料抵扣有没有比例
  • 食堂固定资产折旧年限
  • 法律关系的内容是指
  • 内账和外账会计哪个简单
  • 免税项目进项税为什么不可以抵扣
  • 其他应付款坏账怎么处理
  • 购入资产当月开始计提折旧
  • 多交增值税如何退回
  • 企业采购成本包括所有的仓储费用
  • 个人如何开专票
  • 公司购买床垫怎样入账
  • 企业销售食品过期处罚
  • 利润分配财务处理
  • 斐讯p.to路由器管理员密码
  • 快捷方式都变成pdf
  • 销售免税商品可以抵扣进项税吗
  • mac重装macos
  • 厂房押金收据范本
  • php的用处
  • 企业注销未抵扣完的进项税额怎么处理做账
  • html调查问卷简单代码
  • php判断useragent
  • html5简单吗
  • 数据可视化分析
  • ie11已经为了帮助保护您的计算机而关闭此网页
  • ip6tables-restore命令 还原ip6tables表
  • js去除属性
  • 行政事业性收据丢了怎么办
  • 补记以前年度固定资产怎么记账
  • 蔬菜和肉类是不是免税
  • mysql日志文件在哪
  • 首次购买金税盘怎么做账
  • 汽油发票怎么开专票
  • 实收资本在核算上有哪些要求
  • 工会经费征收项目是什么
  • 本期应补退税额是什么意思
  • 利润表里公允价值变动损益怎么算
  • 收到技术服务费计入什么科目
  • sql指定字段添加数据
  • solaris 2020
  • 快启动u盘pe怎么安装系统详细图文教程
  • Win10 Build 10565 Edge浏览器更新日志和已知问题
  • macbookpro隐藏
  • fedora系统安装教程
  • 电脑如何修改硬盘启动顺序
  • ubuntu 20.04 服务器
  • linux -al
  • linux操作系统版本有哪些
  • win102021年1月大更新
  • linux操作系统的基本操作
  • win10周年更新版是什么意思
  • linux bas
  • linux测试软件
  • jquery直接执行
  • python在web上的应用
  • perl正则表达式
  • jquery easyui开发指南
  • shutil模块 python安装
  • Tcp/ip协议族
  • js实现返回顶部
  • grade 编译
  • 发票查询为什么查不出来
  • 天津税务局投诉举报咨询电话
  • 个人所得税app怎么更改手机号码
  • 病历证明在医院保存多久
  • 税务局风险管理股工作总结
  • 如何理解新时代新征程党的使命任务
  • 山东省准生证是什么样子图片
  • 国办函和国办发
  • 深圳交警的微博
  • 非房地产企业转让旧房土地增值税
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设