JSONP跨域请求数据报错 “Unexpected token :”的解决办法

原创
2014/12/02 14:26
阅读数 3W

本地虚拟两个域名,分别为:www.test.com、www.abc.com

http://www.test.com/index.html页面点击按钮,请求返回www.abc.com域名目录下的文件的数据,其代码为:

<!DOCTYPE html>
<html>
<head>
  <meta charset="utf-8" />
  <title>JSONP跨域请求</title>
  <script src="http://www.oschina.net/js/2012/jquery-1.7.1.min.js" type="text/javascript"></script>
  <script type="text/javascript">
  	$(function(){
      $(".button").on("click",function(){
        $.ajax({
          type:"get",
          url:"http://www.abc.com/json.php",
          dataType:"jsonp",
          jsonp:"callback",
          jsonpCallback:"success_jsonpCallback",
          success:function(json){
            $(".user").html("用户信息:"+json.username+","+json.age+","+json.gender);
          },
          error:function(){
            alert("请求出错!");
          }
        });
      });
  	});
  </script>
</head>
<body>
  <button class="button">点击获取数据</button> 
  <div class="user"></div>
</body>
</html>


http://www.abc.com/json.php文件代码为:

<?php 
$arr = array ('username'=>'jack','age'=>21,'gender'=>'male'); 
echo json_encode($arr);
?>


在Chrome浏览器调试会发现报错了,如图:

json.php返回的数据确实是json类型的数据 {"username":"jack","age":21,"gender":"male"} ,问题处在哪?

翻看了一下Jquery文档发现jsonp:"callback", jsonpCallback:"success_jsonpCallback",传递这两个参数是有原因的,jsonp的返回数据格式应该是: “客户端传递的回调方法名称(json数据)”,将php文件改为:

<?php 
$arr = array ('username'=>'jack','age'=>21,'gender'=>'male'); 
echo $_GET['callback']."(".json_encode($arr).")";
?>


测试,正确返回结果,如下图:


可以看到,php文件返回的结果是 success_jsonpCallback({"username":"jack","age":21,"gender":"male"}) ,这才是正确的jsonp返回格式,而success_jsonpCallback这是传递过去的参数


展开阅读全文
打赏
2
10 收藏
分享
加载中
我的jq 的ajax,pc 和ipad数据请求正常,但是网页的APP和生成的APP都不能请求到数据,error错误,不走success函数,求解
2016/12/13 14:58
回复
举报
正确解决了我的问题,谢谢你的总结
2016/02/29 17:22
回复
举报
更多评论
打赏
2 评论
10 收藏
2
分享
返回顶部
顶部