Ajax_ajax请求中的跨域问题---浏览器不允许ajax跨域获取服务器数据,那我们就用jsonp来实现跨域...

1、认识跨域---跨域获取数据是客观存在的

  实际开发中跨域下还要获取服务端数据这种需求也是很常见的, 因为资源(即使是同一项目,不同子模块)也可能部署在不同的设备上(服务器,不同设备有不同域名或IP地址)。

  

  比如:域名为a的文件通过ajax请求想访问域名为b下的文件---此时发生了跨域请求,浏览器不允许ajax跨域获取服务器数据

    

    

    

    

 2、跨域的解决方式

  

  a、jsonp(jquery中提供了jsonp来解决跨域问题)---主流解决方案(开发接口比较简单,没有兼容性问题)

     

   b、jsonp原理---jsonp致命问题  :只支持get请求(所以最后一般是后台通过技术解决跨域请求问题)

    

    

    

    

    静态的不常用,了解就行,一般用动态创建标签的形式

    

    

    

    -------------------------------------------------------------------------------------------------------------------

    

    

    jsonp的本质并不是Ajax,而是。。。

    

  c、jquery封装好了jsonp跨域获取数据

    

    

    

 

    

    

    

    若后端不叫callback,那前端可以自定义名称,jquery里面写的很灵活(前端迎合后端)

    

       

   c、jsonp应用场景

    

    典型的jsonp接口:标准的第3方接口

     

    用jquery封装好的jsonp调第3方接口(jsonp接口)查数据

    

    

    接口: 后台返回的是数据而不是完整的页面,此时的url就可以说是接口作用,接口类型可按后台返回数据类型类型来分,比如jsonp接口  json格式接口 等

    以下这个网站的接口一般都是json接口,数据都是给后台语言用的,前台想拿到这种json格式数据一般找后台给包装下,再返回给前台使用。

   

     

 

 

     

 

 

    

   

   

   

  

转载于:https://www.cnblogs.com/yangyutian/p/10961754.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值