Angular在Chrome中不起作用

时间:2015-10-26 23:31:41

标签: javascript angularjs google-chrome

我有一个适用于Firefox,IE,Safari和Chrome的应用程序。但是在Chrome中,当下面的控制器运行时它会停止工作。通过不工作我的意思是在$ auth.login(user_info)执行后,promise中的代码失败。例如,如果调用成功返回,则应用程序停止工作。单击任何链接时没有任何反应。 $ location.path(lpath)应该转到主页,但它不会和toastr.success("登录成功");应该显示一条消息,但只显示一个白色的弹出窗口。

如果我使用Chrome.exe --disable-web-security运行Chrome,那么一切正常。有没有人有什么建议?

angular.module("MyApp")
  .controller("LoginCtrl", function($rootScope, $scope, $location, $auth, toastr) {
    var lpath = "/home";
    $scope.login = function() {
      var user_info = { email:$scope.user.email, password:hex_sha512($scope.user.password)} ;
      $auth.login(user_info)
        .then(function(response) 
        {
          if(response.data.rtn == "true") 
          {
            $location.path(lpath);
            toastr.success("Login Success");
          } 
          else 
          {
            toastr.error(response.data.msg);  
          }
        })
        .catch(function(response) 
        {
          toastr.error("Host Login Error!");
        });
    };

  });


  $auth.login = function(user, opts) {
      opts = opts || {};
      opts.url = config.baseUrl ? utils.joinUrl(config.baseUrl, config.loginUrl) : config.loginUrl;
      opts.data = user || opts.data;
      opts.method = opts.method || 'POST';

      return $http(opts).then(function(response) {
        shared.setToken(response);
        return response;
      });
    };

    Shared.setToken = function(response) {
      var accessToken = response && response.access_token;
      var token;

      if (accessToken) {
        if (angular.isObject(accessToken) && angular.isObject(accessToken.data)) {
          response = accessToken;
        } else if (angular.isString(accessToken)) {
          token = accessToken;
        }
      }

      if (!token && response) {
        var tokenRootData = config.tokenRoot && config.tokenRoot.split('.').reduce(function(o, x) { return o[x]; }, response.data);
        token = tokenRootData ? tokenRootData[config.tokenName] : response.data[config.tokenName];
      }

      if (!token) {
        var tokenPath = config.tokenRoot ? config.tokenRoot + '.' + config.tokenName : config.tokenName;
        throw new Error('Expecting a token named "' + tokenPath + '" but instead got: ' + JSON.stringify(response.data));
      }

      storage.set(tokenName, token);
      storage.set(emailName, response.data.email);
      storage.set(permsName, response.data.permissions);

    };

1 个答案:

答案 0 :(得分:1)

发布作为答案,因为我没有代表。

我会说这不是在这个代码中,而是在你的控制器/ home中。您是否尝试删除代码直到它工作?

你确定它确实通过了并且令牌有效吗?尝试清除缓存CTRL-SHIFT-END。您可能会遇到一些需要有效令牌但无法继续的代码,因为您没有捕获失败的案例。

答案(来自Tony):似乎字符串中的句点会导致问题。如果我删除期间它工作正常。