zoukankan      html  css  js  c++  java
  • angular Jsonp的坑

      angular 为了解决跨域问题 一些第三方接口会提供jsonp来调用,需要使用callback=JSON_CALLBACK来处理 

      这个时候问题来了,有些借口是不支持callback里面带有点语法的,最典型的就是豆瓣了,而callback=JSON_CALLBACK 会被 angular转换成 callback = angular.callbacks._[id]这种形式,

      这个时候就会报错了,因为返回的是json格式而不是jsonp格式。为了解决这类问题最简单的方法肯定是重定义方法名,我在这里就是采用这种方法的,但是我们应该怎么改名字呢?答案就是在http拦截器里面,详情看代码。  

    https://api.douban.com/v2/book/isbn/' + isbn + "/reviews?callback=JSON_CALLBACK"
      .factory("httpInterceptor", ["App", "$rootScope", '$injector','$timeout', function (App, $rootScope, $injector,$timeout) {return {
                request: function (config) {
                    if (config.method === 'JSONP') {
                        console.log(config);
                        var callbackId = angular.callbacks.counter.toString(36);
                        config.callbackName = 'angular_callbacks_' + callbackId;
                        config.url = config.url.replace('JSON_CALLBACK', config.callbackName);
    
                        $timeout(function () {
                            window[config.callbackName] = angular.callbacks['_' + callbackId];
                        }, 0, false);
                    }
                    if (!config.isLoading) {
                        count++;
                        $rootScope.$broadcast('loading:show')
                    }
                    return config || App.q.when(config);
                },
                requestError: function (rejection) {               return App.q.reject(rejection)
                },
                response: function (response) {
                   return response || App.q.when(response);
                },
                responseError: function (rejection) {// do something on response error
                    return App.q.reject(rejection);
                }
            }
        }])

      就是以上代码进行方法名更改了。

      以上思路来源于 http://stackoverflow.com/questions/25400891/how-to-custom-set-angularjs-jsonp-callback-name

  • 相关阅读:
    【转】Visual studio 快捷键大全
    C++ 中的权限控制
    论C++11 中vector的N种遍历方法
    c++ 模板仿函数初探
    OBS (open boardcast server)结构分析
    OpenCV学习笔记:opencv_core模块
    [转]C++ new操作符详解
    进程已经被attach debug,如何解除其debug权限?
    dll 在进程中怎么区分的
    树状数组学习笔记
  • 原文地址:https://www.cnblogs.com/HeJason/p/5604835.html
Copyright © 2011-2022 走看看