Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >专栏 >ajax如何解决跨域_除了jsonp还有什么跨域方式

ajax如何解决跨域_除了jsonp还有什么跨域方式

作者头像
全栈程序员站长
发布于 2022-09-23 03:35:29
发布于 2022-09-23 03:35:29
48700
代码可运行
举报
运行总次数:0
代码可运行

大家好,又见面了,我是你们的朋友全栈君。

跨域问题产生的原因

之前做过会员邮箱的录入联想功能,因为数据不在我们的服务器,需要调用其他项目组的接口,虽然可以用PHP调用返回结果到页面,但是不如用ajax直接请求更方便,然而ajax是通过XmlHttpRequest请求,限制只能同源使用,子域名和端口肯定是不一样的,这样没法访问。

JavaScript的”同源策略”,即只有 协议+主机名+端口号 (如存在)相同,则允许相互访问。也就是说JavaScript只能访问和操作自己域下的资源,不能访问和操作其他域下的资源。

常见的跨域场景

URL

说明

是否允许通信

http://www.51job.com/a.js http://www.51job.com/b.js

同一域名,不同路径

允许

http://www.51job.com:8080/a.js http://www.51job.com:8888/b.js

同一域名,不同端口

不允许

http://www.51job.com/a.js https://www.51job.com/b.js

同一域名,不同协议

不允许

http://www.51job.com/a.js http://10.100.51.148/b.js

域名和对应IP

不允许

http://www.51job.com/a.js http://ehire.51job.com/b.js

同一域名,不同子域名

不允许

http://www.51job.com/a.js http://www.51job.com/b.js

不同域名

不允许

跨域的解决方案

img、iframe 、script标签可以通过src属性请求到其他服务器上的数据,利用这一开放策略,通过动态添加script标签来调用服务器,返回是的生成的可执行js代码,数据作为回调函数的参数,执行完毕后script标签会被移除。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
  $.ajax(
    { 
   
      url: url, //路径
      async: false, //同步
      type: "get", //请求方式
      dataType: "jsonp", //跨域
      jsonp: "callback", //回调函数的参数名,可自动生成
      data: data, //发送数据
      cache: false,
      /*发送前执行方法*/
      beforeSend: function () { 
    },
      /*成功执行方法*/
      success: function (res) { 
   
          res = eval(res); //执行
          data = unescape(res).split('\t'); //解码
	  },
      /*完成执行方法*/
      complete: function () { 
    },
      /*失败执行方法*/
      error: function () { 
    }
    });

注意只支持 get方式,也可以用 iframe 设置 src 指向本地域的代理文件,监听引入外部 html 并在 window.name 对象里存取数据,但要及时销毁。

服务器端也需要更改配置,允许任何域发起的请求都可以获取当前服务器的数据,但是非常不安全,容易受到XSS攻击,通常会做白名单限制。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
    //api 入口
	if (in_array($requestHost,[$domainInt['host']])) { 
   //允许跨域
	    header('Access-Control-Expose-Headers: Apistatus,Content-Disposition');
	    header('Access-Control-Allow-Origin:*');
	}

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/172554.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
详解JavaScript跨域问题
什么是跨域? 概念:只要协议、域名、端口有任何一个不同,都被当作是不同的域。 URL 说明 是否允许通信 http://www.a.com/a.js http://www.a.com/b.js 同一域名下 允许 http://www.a.com/lab/a.js http://www.a.com/script/b.js 同一域名下不同文件夹 允许 http://www.a.com:8000/a.js htt
前朝楚水
2018/04/03
1.1K0
JS 跨域问题常见的五种解决方式
要理解跨域问题,就先理解好概念。跨域问题是由于javascript语言安全限制中的同源策略造成的.
书童小二
2018/09/03
1.6K0
JS 跨域问题常见的五种解决方式
跨域详解 【原创】
跨域详解 Write By CS逍遥剑仙 我的主页: www.csxiaoyao.com GitHub: github.com/csxiaoyaojianxian Email: sunjianfeng@csxiaoyao.com QQ: 1724338257 目录导航 跨域详解 1. 概念 2. 跨域资源共享(CORS) 3. jsonp跨域 3.1 概念 3.2 实现 3.3 jQuery封装操作 3.4 JSONP优缺点 CORS 与 J
CS逍遥剑仙
2018/04/28
1.4K0
前端,什么是跨域,及跨域常见的解决方案(简讲)「建议收藏」
同源策略,其初衷是为了浏览器的安全性,通过以下三种限制,保证浏览器不易受到XSS、CSFR等攻击。
全栈程序员站长
2022/08/30
2K0
Web前端学习笔记之前端跨域知识总结
相信每一个前端er对于跨域这两个字都不会陌生,在实际项目中应用也是比较多的。但跨域方法的多种多样实在让人目不暇接。老规矩,碰到这种情况,就只能自己总结一篇博客,作为记录。
Jetpropelledsnake21
2018/08/10
1.1K0
ajax实现跨域_js跨域请求的三种方法
跨域大家都知道,不同地址,不同端口,不同级别,不同协议都会构成跨域。例如:about.haorooms.com和www.haorooms.com都会构成跨域。总结起来只要协议、域名、端口有任何一个不同,都被当作是不同的域。下面举例,每两个一组。
全栈程序员站长
2022/09/23
2.9K0
js跨域解决方案
在页面渲染时需要动态获取iframe子页面的高度,然后重新设置iframe高度,达到自适应的目的,但是由于iframe子页面中也涉及到访问其他系统的页面,这就使得页面渲染时无法获取子页面高度,这里涉及到跨域访问子页面问题。
一笠风雨任生平
2019/08/02
4.1K0
跨域请求方案 终极版
现在是资源共享的时代,同样也是知识分享的时代,如果你觉得本文能学到知识,请把知识与别人分享。
互扯程序
2018/07/30
3.8K0
JS跨域请求解决方案
同源策略/SOP(Same origin policy)是一种约定,由Netscape公司1995年引入浏览器,它是浏览器最核心也最基本的安全功能,如果缺少了同源策略,浏览器很容易受到XSS.CSFR等攻击。所谓同源是指”协议+域名+端口”三者相同,即便两个不同的域名指向同一个ip地址,也非同源。
码客说
2019/10/22
5.2K0
JsonP------实现跨域请求
JsonP技术 介绍 JsonP 跨域 同源策略 非同源限制以下行为 常见的跨域场景 跨域的解决方案 JsonP的优缺点 Json的使用 搭建应用场景 JsonP实现手动跨域 jsonDemo1的jsp页面(发送跨域请求) jsonDemo2的controller JsonUtils工具类(需要添加相关坐标jackson-databind) 实现自动跨域(SpringMVC对JsonP的支持) jsonDemo1的jsp页面同上 jsonDemo2的controller 介绍 JsonP Jsonp
时间静止不是简史
2020/07/25
1.2K0
你真的了解跨域吗
相信每个前端对于跨域这两个字都不会陌生,在实际项目中应用也很多,但跨域方法的多种多样让人目不暇接,前段时间公司同事出现了跨域问题,又一时找不到问题所在,所以在此总结下跨域知识,一篇由浅入深的万字Web基操文
isboyjc
2022/03/28
2.4K0
你真的了解跨域吗
一篇文章让你搞懂如何通过Nginx来解决跨域问题
出于安全考虑(比如csrf攻击),浏览器一般会禁止进行跨域访问,但是因为有时有相应需求,需要允许跨域访问,这时,我们就需要将跨域访问限制打开。   启动一个web服务,端口是8081
用户4919348
2020/06/21
39.5K2
JavaScript第九弹——探究跨域
Hello小可爱们~~我又来了,还记得昨天说的今天要说什么吗???是滴,今天要说的就是跨域!
萌兔IT
2019/07/25
5380
什么是跨域及怎么解决跨域问题?[通俗易懂]
这篇博文解释的挺清楚,我直接引用 什么是跨域?怎么解决跨域问题?_L瑜-CSDN博客_跨域是什么意思
全栈程序员站长
2022/08/11
12.9K0
什么是跨域及怎么解决跨域问题?[通俗易懂]
【Ajax进阶】跨域和JSONP的学习
例如,下表给出了相对于http://www.test.com:80/index.html 端口号不写,默认为80.。
坚毅的小解同志的前端社区
2022/11/28
1.2K0
【Ajax进阶】跨域和JSONP的学习
Ajax技术详解(上)
我们知道,在没有ajax技术之前,客户端若要与服务端进行数据交互,它的大概流程是:客户端发起一个http请求(也可能是其他的请求)然后处于等待状态,等到服务端将数据发送给客户端,客户端才会进行下一步操作,简单来讲,就是单纯的同步操作。然而,在现如今这个用户至上的年代,任何一个让用户不满的小操作都会导致巨大的流量丢失。
石璞东
2020/05/09
2K0
AJAX 与跨域通信(二):跨域解决方案
本篇讲解常见的几种跨域方案:JSONP、CORS、图像Ping、document.domain、window.name。
Chor
2019/11/11
1.4K0
AJAX 与跨域通信(二):跨域解决方案
ajax跨域解决方案domain_js解决跨域问题
JSON是一种轻量级的数据传输格式,被广泛应用于当前Web应用中。JSON格式数据的编码和解析基本在所有主流语言中都被实现,所以现在大部分前后端分离的架构都以JSON格式进行数据的传输。
全栈程序员站长
2022/09/23
2.5K0
ajax跨域解决方案domain_js解决跨域问题
ajax跨域的解决办法_java如何解决跨域问题
大家好,又见面了,我是你们的朋友全栈君。 什么是跨域问题? 跨域问题来源于JavaScript的”同源策略”,即只有 协议+主机名+端口号 (如存在)相同,则允许相互访问。也就是说JavaScrip
全栈程序员站长
2022/09/23
7040
【Web技术】424- 那些年曾谈起的跨域
对于前端开发来说跨域应该是最不陌生的问题了,无论是开发过程中还是在面试过程中都是一个经常遇到的一个问题,在开发过程中遇到这个问题的话一般都是找后端同学去解决,以至于很多人都忽略了对跨域的认识。为什么会导致跨域?遇到跨域又怎么去解决呢?本文会对这些问题一一的介绍。
pingan8787
2019/11/30
5850
相关推荐
详解JavaScript跨域问题
更多 >
领券
社区富文本编辑器全新改版!诚邀体验~
全新交互,全新视觉,新增快捷键、悬浮工具栏、高亮块等功能并同时优化现有功能,全面提升创作效率和体验
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文