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

  • 稳定个人博客流量的四个办法(个人博客怎么引流)

    稳定个人博客流量的四个办法(个人博客怎么引流)

  • iphone主副卡怎么切换(iphone主副卡怎么安装)

    iphone主副卡怎么切换(iphone主副卡怎么安装)

  • 安卓手机如何刷机(安卓手机如何刷公交卡)

    安卓手机如何刷机(安卓手机如何刷公交卡)

  • 苹果xr充满电一次可以用多久(苹果xr电充满了会自动断电吗)

    苹果xr充满电一次可以用多久(苹果xr电充满了会自动断电吗)

  • 华为手机怎么测试wifi网速(华为手机怎么测心率)

    华为手机怎么测试wifi网速(华为手机怎么测心率)

  • 苹果11自带浏览器打不开(苹果11自带浏览器怎么扫一扫)

    苹果11自带浏览器打不开(苹果11自带浏览器怎么扫一扫)

  • 通信设计是做什么(通信设计有没有前景)

    通信设计是做什么(通信设计有没有前景)

  • 滴滴闪退解决办法(滴滴闪退解决办法有哪些)

    滴滴闪退解决办法(滴滴闪退解决办法有哪些)

  • ipad算不算电脑端(ipad算不算电脑在线)

    ipad算不算电脑端(ipad算不算电脑在线)

  • cpu速度指的是什么(cpu的速度主要取决于哪三样)

    cpu速度指的是什么(cpu的速度主要取决于哪三样)

  • 电脑微信怎么开摄像头(电脑微信怎么开小程序)

    电脑微信怎么开摄像头(电脑微信怎么开小程序)

  • vivoz5后盖是塑料吗(vivo z5后盖)

    vivoz5后盖是塑料吗(vivo z5后盖)

  • 苹果7怎么开视频美颜(苹果7怎么开视频聊天)

    苹果7怎么开视频美颜(苹果7怎么开视频聊天)

  • 苹果x用的什么基带(苹果x用的什么处理器)

    苹果x用的什么基带(苹果x用的什么处理器)

  • word的除号怎么打(word中的除号)

    word的除号怎么打(word中的除号)

  • vue怎么分段添加字幕(vue分栏)

    vue怎么分段添加字幕(vue分栏)

  • 苹果x到底防不防水(苹果x防摔功能是真的吗)

    苹果x到底防不防水(苹果x防摔功能是真的吗)

  • 淘宝店铺如何发送链接(淘宝店铺如何发布商品视频)

    淘宝店铺如何发送链接(淘宝店铺如何发布商品视频)

  • 内存插在主板哪个槽(内存插在主板哪个位置)

    内存插在主板哪个槽(内存插在主板哪个位置)

  • 小黑记事本护眼模式怎么关闭(小黑记事本护眼精灵怎么卸载)

    小黑记事本护眼模式怎么关闭(小黑记事本护眼精灵怎么卸载)

  • 条码打印机设置(条码打印机设置纸张大小为什么不能设置)

    条码打印机设置(条码打印机设置纸张大小为什么不能设置)

  • 电池健康怎么看(苹果电池健康怎么看)

    电池健康怎么看(苹果电池健康怎么看)

  • 小米的标志设计理念是什么(小米的标志设计理念)

    小米的标志设计理念是什么(小米的标志设计理念)

  • XP系统CAD连接办公室局域网中的打印机打印图纸的(xp系统可以安装cad吗)

    XP系统CAD连接办公室局域网中的打印机打印图纸的(xp系统可以安装cad吗)

  • scards32.exe - scards32是什么进程 有什么用

    scards32.exe - scards32是什么进程 有什么用

  • nodejs安装与卸载(高版本降为低版本)(node 卸载)

    nodejs安装与卸载(高版本降为低版本)(node 卸载)

  • vue3使用svg图标多种方式(vue引用svg矢量图)

    vue3使用svg图标多种方式(vue引用svg矢量图)

  • OpenGL ES 名词解释(二)(openglskia是什么意思)

    OpenGL ES 名词解释(二)(openglskia是什么意思)

  • 什么是税收超额征收
  • 公司户和个人户卖车的时候价格差多少
  • 人工费用的核算例题
  • 劳动合同和劳务合同有什么区别 举例
  • 税款已交更正申报
  • 社保免征还需要申报吗
  • 个税申报初始化密码
  • 金税盘备份文件名
  • 缴纳所得税费用的会计分录
  • 2020年关于住房公积金的新规定
  • 如何建设工厂
  • 处置固定资产增值税和所得税报税能一致吗
  • 建筑工程外地预交税款后完工怎么办
  • 出口收汇核销单取消了吗
  • 以旧换新的金子划算吗
  • 用于集体福利的消费税
  • 私车公用违规吗
  • 研发项目领原料加工成产品会计处理是怎样的?
  • 劳动合同中的劳动报酬标准
  • 增值税发票价税合计是什么意思
  • 7月1日起,中药生产企业增值税税率为多少?
  • 公司个人所得税怎么申报
  • 分担总部费用
  • 员工给公司代垫的款项分录
  • 收到负数购入发票怎么办
  • 周转材料购置费属于材料费吗
  • 固定资产出售收入属于什么收入
  • 怎么隐藏单元
  • 如何解决win7系统卡顿
  • paddle!
  • 一般纳税人购进税控收款机抵扣
  • 公司房产处置
  • 环境检测费做什么科目
  • php对象的概念
  • php获取指定数量的数据
  • 支票沾水
  • 电商后台管理系统简介
  • oc底层原理
  • 狗能看懂的电视
  • linux执行php脚本
  • 小微企业的增值税税收优惠政策
  • 个体工商户生产经营所得税税率表2023
  • 银行承兑到期后几天内有效
  • discuzcms
  • 财务报表如何看
  • 印花税不减免
  • 汇算清缴补缴所得税摘要怎么写的
  • PostgreSQL 角色与用户管理介绍
  • 只有进项税需要结转吗
  • 上年度税金及附加多提了,调整后怎么改年报
  • 个体户需要实缴吗
  • 公司模具部制作工作内容
  • 外贸出口企业如何申报增值税
  • 经营租赁方式租入再转租的建筑物
  • 开票方没有缴纳增值税
  • 法人转移公司资产怎么办
  • 直接计入管理费用的税金有哪些
  • 财税讲座视频
  • 工业企业固定资产投资
  • 数据库性能优化面试题
  • 如何远程重装系统教程
  • windows10的便签纸在哪
  • scrtkfg.exe - scrtkfg是什么进程 有什么用
  • win10搜索功能不好用
  • win 7系统无法删除系统文件
  • win10插上耳机后电脑还是外放如何解决
  • win7系统误删文件可以恢复吗
  • express sendfile
  • javascript闭包详解
  • dirsearch批量
  • jquery中删除节点方法
  • Python实现以时间换空间的缓存替换算法
  • unity-
  • 对jquery的ajax进行二次封装以及ajax缓存代理组件:AjaxCache详解
  • javascript definitive guide
  • javascript基础笔记
  • 安卓手机安装推特
  • python汉字
  • 全国退休人员有几多人
  • 广东发票开票软件
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设