一.ajax的同源策略

Ajax请求限制:

Ajax 只能向自己的服务器发送请求。比如现在有一个A网站、有一个B网站,A网站中的 HTML 文件只能向A网站服务器中发送 Ajax 请求,B网站中的 HTML 文件只能向 B 网站中发送 Ajax 请求,但是 A 网站是不能向 B 网站发送 Ajax请求的,同理,B 网站也不能向 A 网站发送 Ajax请求。

XMLHttpRequest

fetch() 封装了ajax

同源策略:

什么叫做同源

如果两个页面拥有相同的协议、域名和端口,那么这两个页面就属于同一个源,其中只要有一个不相同,就是不同源。
http://www.example.com/dir/page.html
http://www.example.com/dir2/other.html:同源
http://example.com/dir/other.html:不同源(域名不同)
http://v2.www.example.com/dir/other.html:不同源(域名不同)
http://www.example.com:81/dir/other.html:不同源(端口不同)
https://www.example.com/dir/page.html:不同源(协议不同)

什么叫同源策略

同源策略是浏览器的一个安全功能,不同源的客户端脚本在没有明确授权的情况下,不能读写对方资源

同源策略的目的

同源策略是为了保证用户信息的安全,防止恶意的网站窃取数据。最初的同源政策是指 A 网站在客户端设置的 Cookie,B网站是不能访问的。

随着互联网的发展,同源政策也越来越严格,在不同源的情况下,其中有一项规定就是无法向非同源地址发送Ajax 请求,如果请求,浏览器就会报错。

二.jsonp跨域

使用JSONP解决同源限制问题

jsonp的原理:页面上的很多标签比如src,href,都不会受到同源策略的影响

有一些标签天生就有跨域能力,比如:img,link,iframe,script

jsonp就是利用<script>的src来实现跨域获取数据的,只支持get请求

jsonp 由两部分组成:回调函数和数据,回调函数是当响应到来时应该在页面中调用的函数。回调函数的名字一般是在请求中指定的。而数据就是传入回调函数中的 JSON 数据

jsonp 是 json with padding 的缩写,它不属于 Ajax 请求,但它可以模拟 Ajax 请求。

  1. 将不同源的服务器端请求地址写在 script 标签的 src 属性中

     <script src="www.example.com"></script>
    
  2. 服务器端响应数据必须是一个函数的调用,真正要发送给客户端的数据需要作为函数调用的参数。

     const data = 'fn({name: "张三", age: "20"})';echo data;
    
  3. 在客户端全局作用域

    function fn(data){}
    
  4. 在fn函数内部对服务器端返回的数据进行处理

    function fn(data){console.log(data);
    }
    

整体实现思路:

  1. 客户端需要将函数名称传递到服务器端
  2. 将script请求的发送变成动态的请求。
 <script>function fn(data){console.log(data);}
//  接收后端响应的数据
</script><script src="data.php?callback=fn"></script>

​ 后端:

<?php$cb = $_GET['callback']; //接收前端的参数:callback  fn$data = "i am back";echo $cb.'("'.$data.'")'; // fn('123')
?>echo '字符串'

高级版实现:

 <script>function fn1(data) {console.log('客户端的fn函数被调用了');console.log(data);}function add(){// 创建srcipt标签var oSrc = document.createElement('script');oSrc.src = 'http://192.168.52.1/workspace/demo/code3/data.php?callback=fn1';document.body.appendChild(oSrc);// 监听script标签什么时间加载完成,oSrc.onload = function(){oSrc.remove();}}</script>

高级封装

1. 客户端需要将函数名称传递到服务器端
2. 将script请求的发送变成动态请求
3. 封装jsonp函数,方便请求发送
<script>function add() {jsonp({url: 'http://192.168.52.1/workspace/data.php',data:{},success:function(data){console.log(data);}})}function jsonp(options) {var script = document.createElement('script');var fn = 'myscript'+Math.random().toString().replace('.','');//生成随机函数名window[fn]=options.success;script.src = options.url+'?callback='+fn+getParams(options.data);document.body.appendChild(script);// 监听script标签什么时间加载完成,script.onload = function () {script.remove();}}function getParams(obj){var arr = [];for(var k in obj){arr.push(k+'='+obj[k]);}return arr;}</script>

三.服务器端跨域

CORS:全称为 Cross-origin resource sharing,即跨域资源共享,它允许浏览器向跨域服务器发送 Ajax 请求,克服了 Ajax 只能同源使用的限制。

前端请求地址:

http://192.168.52.1/workspace/day05/cros.php

后端设置:

 Access-Control-Allow-Origin: 'http://localhost:3000'Access-Control-Allow-Origin: '*'

header(‘Access-Control-Allow-Origin: *’);
如果想设置只允许某个网站通过的话可以这样设置
header(’Access-Control-Allow-Origin: http://test.com‘); // 允许test.com发起的跨域请求,其他的都不通过

六. 请求天气预报

接口文档:

      请求方式:GET     请求地址: 'https://wis.qq.com/weather/common',必要参数:province: "陕西省",city: "西安市",source:'pc',weather_type:'forecast_1h'

搜索框自动搜索

<!DOCTYPE html>
<html><head><title></title><meta http-equiv="content-type" content="text/html; charset=utf-8">
</head><body><input type="text"><script src="./jsonp.js"></script><script>var oTxt = document.querySelector('input')oTxt.oninput = function () {jsonp({type:'GET',url: 'https://suggest.taobao.com/sug',data: {q: this.value,},success: function (data) {console.log(data);}})}</script>
</body></html>

js高级--jsonp跨域相关推荐

  1. 原生js的JSONP跨域请求

    但到目前为止最被推崇或者说首选的方案还是用JSON来传数据,靠JSONP来跨域. JSONP跨域GET请求是常用的解决方案. 在进行一些比较深入的前端操作时,不可避免的要进行跨域操作,但是 基于安全的 ...

  2. JS的jsonp是什么?5分钟学会jsonp跨域请求

    一.jsonp是什么? jsonp是解决跨域请求的一种技术.浏览器为了防止CSRF攻击会采用同源策略(协议/主机/端口均相同)限制,对非同源发起http请求(即跨域请求)会被浏览器阻止. 二.json ...

  3. 原生JS封装Ajax插件(同域jsonp跨域)

    2019独角兽企业重金招聘Python工程师标准>>> 抛出一个问题,其实所谓的熟悉原生JS,怎样的程度才是熟悉呢? 最近都在做原生JS熟悉的练习... 用原生Js封装了一个Ajax ...

  4. 原生JS实现Ajax和JSONP跨域请求

    背景: 对接身份证录入和门锁卡号录入设备中,安装驱动完成后,提供的接口服务是http://localhost:8099/?cmd=readbcardid&charset=gbk,返回的数据格式 ...

  5. 【JS】AJAX跨域-JSONP解决方案(一)

    [JS]AJAX跨域-JSONP解决方案(一) 参考文章: (1)[JS]AJAX跨域-JSONP解决方案(一) (2)https://www.cnblogs.com/h--d/p/11470534. ...

  6. [JS]笔记18_AJAX2_iframe元素AJAX跨域JSONP跨域

    1.iframe元素 iframe元素会创建包含另外一个文档的内联框架 常用属性: frameborder属性规定是否显示框架周围的边框 值:0/1 src属性规定要显示的文档的URL 可是:html ...

  7. jsonp 跨域原理详解

    转载至:http://zha-zi.iteye.com/blog/1975116 JavaScript是一种在Web开发中经常使用的前端动态脚本技术.在JavaScript中,有一个很重要的安全性限制 ...

  8. JSONP跨域的原理解析

    JavaScript是一种在Web开发中经常使用的前端动态脚本技术.在JavaScript中,有一个很重要的安全性限制,被称为"Same-Origin Policy"(同源策略). ...

  9. JSONP跨域的原理解析及其实现介绍

    JSONP 即 Json padding ,JSONP跨域GET请求是一个常用的解决方案,下面我们来看一下JSONP跨域是如何实现的,并且探讨下JSONP跨域的原理 JavaScript是一种在Web ...

  10. 实现百度下拉菜单实例(利用jsonp跨域请求百度数据接口)

    JSONP:是JSON  with padding(填充式JSON或参数式JSON)的简写,它由两部分组成:回调函数和数据.回调函数是当响应到来时应该在页面中调用的函数,回调函数的名字一般是在请求中指 ...

最新文章

  1. 索引是建的越多越好吗?
  2. 漫画 | 程序媛小姐姐带你一次了解什么是排序算法
  3. 今日头条CEO朱文佳:新一代搜索引擎已经来了
  4. win10 安装cuda黑屏解决
  5. 【机器视觉】 measure_pos算子
  6. Java集合—HashMap为什么2倍扩容
  7. 30是什么意思_“29+16”变“30+18”是什么意思?独立艺术院校有何优势?报考需要注意什么?...
  8. 【转】Dicom 学习笔记-Dicom 消息服务(DIMSE-C/DIMSE-N)
  9. ECS 与 BCH的使用心得 - 引用篇
  10. Web Hacking 101 中文版 十四、XML 外部实体注入(二)
  11. 企业信息安全模型(成熟度模型)
  12. OpenGL天空盒skybox
  13. 12306 官网硬卧下铺的选择
  14. Reed-Solomon Codes——RS纠错码
  15. 台式计算机关机后自行重启,台式电脑点关机后又自动重启怎么处理
  16. python爬虫豆瓣高分电影前一百部
  17. 前端下载pdf文档(支持doc/excel/ppt/pdf/jpg、png等)
  18. 每个计算机主机只有一个硬盘吗,电脑多加一个硬盘需要重装系统吗? 电脑如何新增加一块硬盘...
  19. android程序怎么执行,电脑怎么运行安卓手机程序【详细介绍】
  20. Jmeter连接sqlSever踩的坑

热门文章

  1. 什么叫pmt测试分析_DVT测试是什么意思?(smt术语详解)
  2. 磁珠的串联和并联分析:
  3. 关于数位板电脑绘画——入门篇
  4. 制作STM32F429的外部SPI-FLASH下载算法
  5. 【VMware vSphere】Veeam备份
  6. vue实现在线客服功能(附完整代码)
  7. AD20笔记-PCB设计
  8. order by排序的用法
  9. 数据库系统设计综合实验
  10. matlab柱状图的绘制及数值的标注