码迷,mamicode.com
首页 > Web开发 > 详细

AngularJs最简单解决跨域问题案例

时间:2017-01-13 22:48:58      阅读:278      评论:0      收藏:0      [点我收藏+]

标签:blog   comm   问题   oct   简单   mod   function   lan   har   

我们以两个主域名或者一个主域名+一个二级域名为例,均可演示跨域问题。

  • 客户端 a.com
  • 服务端 b.com或者s.a.com
  • angularJs版本 V1.2.25

准备工作做得很充分嘛,就差把我们的编辑器是subline暴露出来了,这个一般人我是不告诉他滴。

有人嚷嚷了,这问题老早就有了,你现在提出来有啥意义呢?难不成你还能把花忽悠开了?嗯,我还真能把花写开了。看戏吧,我们本篇要上演的是完整版跨域实例。

接下来我们先看客户端是如何请求数据的

注意哦,我们的代码是写在a.com域名下面的

技术分享
<!DOCTYPE html>
<html lang="en" ng-app="app">
<head>
    <meta charset="UTF-8">
    <title></title>
    <script src="./angular.min.js"></script>
    <script type="text/javascript">
        var app = angular.module(‘app‘, []);
        app.controller(‘appCtrl‘, [‘$scope‘,‘$http‘, function ($scope,$http) {
            $http({
                method: ‘JSONP‘,
                url: ‘http://www.b.com/test.php?callback=JSON_CALLBACK‘,
            }).success(function (msg) {
                console.log(msg);
            });
            //或者
            $http
                .jsonp(‘http://www.b.com/test.php?callback=JSON_CALLBACK‘)
                .success(function (msg){
                    console.log(msg);
                }); 
        }]);
    </script>
</head>
<body>
</body>
</html>
技术分享

 

我们看到,这里是直接以jsonp的形式进行跨域请求的,其操作同jquery中对跨域的请求方式如出一辙。注意,我们的callback是固定的,即JSON_CALLBACK,尽量不要去做任何改动

我们再看服务端b.com中的test.php对请求数据的处理方式,这里以原生php的方式做参考

$callBack = isset($_GET[‘callback‘]) ? $_GET[‘callback‘] : DEFAULT_CALLBACK;
exit($callBack.‘(‘.json_encode($data).‘)‘);

AngularJs最简单解决跨域问题案例

标签:blog   comm   问题   oct   简单   mod   function   lan   har   

原文地址:http://www.cnblogs.com/aishangliming/p/6284126.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!