实现跨域请求的4种方法

模拟服务器端的PHP文件:

service:

<?php//允许访问header(‘Access-Control-Allow-Origin:*‘);@$callback=$_GET[‘callback‘];//创建数据$userInfo = array(‘id‘=>1,‘username‘=>‘Scott Jeremy‘,‘email‘=>‘[email protected]‘);//编译成JSON$result = json_encode($userInfo);echo $callback."({$result})";

service2:

<?phpheader(‘Access-Control-Allow-Origin:*‘);$userInfo = array(‘id‘=>1,‘username‘=>‘Scott Jeremy‘,‘email‘=>‘[email protected]‘);echo json_encode($userInfo);

原生Javascript:

function jsonpCallback(result) {    //alert(result);会返回jsonpCallback({"id":1,"username":"Scott Jeremy","email":"[email protected]"})    alert(‘My :‘+result.username+‘.‘+‘My email:‘+result.email);}//创建script标签var script = document.createElement(‘script‘);//定义script标签的urlscript.src = ‘http://localhost/service.php?callback=jsonpCallback‘;//把标签放到head中document.getElementsByTagName(‘head‘)[0].appendChild(script);

利用jQuery实现跨域请求有三种方法:

1:AJAX请求
$(‘#btn1‘).on(‘click‘,function () {    $.ajax({    //设置url        url:‘http://localhost/service2.php‘,    //用什么方式请求        type:‘GET‘,    //返回来用什么形式解析        dataType:‘json‘,        success:function (data) {            alert(data.username);            alert(data.email);        },        error:function () {            alert(‘error‘);        }    });});

2:JSONP实现跨域请求
$(‘#btn2‘).on(‘click‘,function () {    $.ajax({        url:‘http://localhost/service.php‘,        type:‘GET‘,        dataType:‘JSONP‘,    //JSONP回调函数名        jsonp:‘callback‘,    //JSONP回调后的JSON名,相当于JSON文章中的book        jsonpCallback:‘Jeremy‘,        success:function (data) {            alert(data.username);            alert(data.email);        }    })});
3:getJSON(最简单的一种:缩写)
$(‘#btn3‘).on(‘click‘,function () {    $.getJSON(‘http://localhost/service.php?callback=?‘,function (data) {        alert(data.username);        alert(data.email);    })});
 
时间: 2024-12-15 23:52:18

实现跨域请求的4种方法的相关文章

项目中经常遇到的跨域请求的几种方法

什么是跨域 JSONP proxy代理 cors xdr 关于跨域无非就是jsonp和iframe,随着跨域请求的应用越来越多,W3C提供了跨域请求的标准方案(Cross-Origin Resource Sharing).IE8.Firefox 3.5 及其以后的版本.Chrome浏览器.Safari 4 等已经实现了 Cross-Origin Resource Sharing 规范,实现了跨域请求.在服务器响应客户端的时候,带上Access-Control-Allow-Origin头信息. 如

ASP.NET MVC 实现AJAX跨域请求的两种方法

通常发送AJAX请求都是在本域内完成的,也就是向本域内的某个URL发送请求,完成部分页面的刷新.但有的时候需要向其它域发送AJAX请求,完成数据的加载,例如Google. 在ASP.NET MVC 框架里实现跨域的AJAX请求有几种方式可以实现,以下就介绍常用的两种方法. 1.     发送JSONP请求 客户端: JQuery对发送JSONP请求有很好的支持,客户端通过. ajax() 函数发送请求,其中需要制定 dataType 为“jsonp”  jsonpCallback 为指定的回调函

解决前端跨域请求的几种方式

利用 JSONP 实现跨域调用 说道跨域调用,可能大家首先想到的或者听说过的就是 JSONP 了. 1.1 什么是JSONP JSONP 是 JSON 的一种使用模式,可以解决主流浏览器的跨域数据访问问题.其原理是根据 XmlHttpRequest 对象受到同源策略的影响,而 <script> 标签元素却不受同源策略影响,可以加载跨域服务器上的脚本,网页可以从其他来源动态产生 JSON 资料.用 JSONP 获取的不是 JSON 数据,而是可以直接运行的 JavaScript 语句. 1.2

本地主机作服务器解决AJAX跨域请求访问数据的方法

近几天学到ajax,想测试一下ajax样例,由于之前在阿里租用的服务器过期了,于是想着让本地主机既做服务器又做客户端,只是简单地测试,应该还行. 于是,下载了xampp,下载网址http://www.apachefriends.org ,只需要解压傻瓜式地安装就可以. 找到安装软件的目录,点击xampp-control.exe然后启动Apache服务, 打开浏览器,在地址栏输入localhost,出现如下图片,说明安装启动都没问题 现在编写两个简单的文本,一个txt文件,一个html代码: 截图

跨域请求的3种方式

视频教程 跨域请求的方式:3种 1.后台代理 2.jsonp 3.HTML5中的XHR2 需要前端会的方法是后两种. 2.jsonp使用方法:只支持get方式 $.ajax({dataType:"jsonp",jsonp:"callback",success:...,error:...});//前台,修改数据类型,定义jsonp属性和参数名,等待后台调用 var request=$_GET("callback");//后台,接收前台定义好的参数名

跨域请求的三种解决

第一种:jsonp的方式 <?php header('Content-type: application/json'); //获取回调函数名 $jsoncallback = $_GET['jsoncallback']; //json数据 $json_data = '{"data":[{"did":"29","deptName":"\u8f6f\u4ef6\u90e8"}, {"did&quo

如何跨域访问的两种方法~

1. JSONP,需要客户端与服务端配合    什么是:填充式JSON--JSON with Padding    何时: 今后跨域,首选jsonp    如何:      基本思想:用其它可以跨域请求的元素,代替ajax     程序中都是用<script>元素代替ajax发送请求     方案一:       1. 服务端: 将要返回的数据,填充进一条字符串格式的js语句中,组成一条正确的可执行的js语句,再返回      2. 客户端: 添加<script src="服务

服务器端解决跨域问题的三种方法

跨域是指html文件所在的服务器与ajax请求的服务器是不同的ip+port,例如: - ‘192.168.1.1:8080’ 与 ‘192.168.1.2:8080’是不同的域. - ‘192.168.1.1:8080’ 与 ‘192.168.1.1:8081’是不同的域. 解决此类问题的方法很多,有需要客户端和服务端都要更改的,例如jsonp,iframe等等:有只需要客户端更改的,这种情况只能出现在hybrid app开发中,即通过调用native方法来进行网络请求:有只需要服务端配置的,

php 跨域 form提交 2种方法

出于安全因素考虑,直接跨域访问是不允许的,下面介绍二种跨域的方法. 一,通过php curl function curlPost($url,$params) { $postData = ''; foreach($params as $k => $v) { $postData .= $k . '='.$v.'&'; } rtrim($postData, '&'); $ch = curl_init(); curl_setopt($ch,CURLOPT_URL,$url); curl_se