2016-08-23 8 views
1

私は、プレイアプリケーション(スカラー付き)で認証の例を実装しようとしています。私はこれに従いますtutorial"use strict"の関数形式を使用してください。 anglejs認証(scala、play framework)

私は認証のためのインデックスページを作成しました。

'use strict'; 

angular.module('Authentication') 


    .controller('LoginController', 
     ['$scope', '$rootScope', '$location', 'AuthenticationService', 
     function ($scope, $rootScope, $location, AuthenticationService) { 
      // reset login status 
      AuthenticationService.ClearCredentials(); 

      $scope.login = function() { 
       $scope.dataLoading = true; 
       AuthenticationService.Login($scope.username, $scope.password, function(response) { 
        if(response.success) { 
         AuthenticationService.SetCredentials($scope.username, $scope.password); 
         $location.path('/'); 
        } else { 
         $scope.error = response.message; 
         $scope.dataLoading = false; 
        } 
       }); 
      }; 
     }]); 

と、この:

'use strict'; 

angular.module('Authentication') 

.factory('AuthenticationService', 
    ['Base64', '$http', '$cookieStore', '$rootScope', '$timeout', 
    function (Base64, $http, $cookieStore, $rootScope, $timeout) { 
     var service = {}; 

     service.Login = function (username, password, callback) { 

      /* Dummy authentication for testing, uses $timeout to simulate api call 
      ----------------------------------------------*/ 
      $timeout(function(){ 
       var response = { success: username === 'test' && password === 'test' }; 
       if(!response.success) { 
        response.message = 'Username or password is incorrect'; 
       } 
       callback(response); 
      }, 1000); 


      /* Use this for real authentication 
      ----------------------------------------------*/ 
      //$http.post('/api/authenticate', { username: username, password: password }) 
      // .success(function (response) { 
      //  callback(response); 
      // }); 

     }; 

     service.SetCredentials = function (username, password) { 
      var authdata = Base64.encode(username + ':' + password); 

      $rootScope.globals = { 
       currentUser: { 
        username: username, 
        authdata: authdata 
       } 
      }; 

      $http.defaults.headers.common['Authorization'] = 'Basic ' + authdata; // jshint ignore:line 
      $cookieStore.put('globals', $rootScope.globals); 
     }; 

     service.ClearCredentials = function() { 
      $rootScope.globals = {}; 
      $cookieStore.remove('globals'); 
      $http.defaults.headers.common.Authorization = 'Basic '; 
     }; 

     return service; 
    }]) 

.factory('Base64', function() { 
    /* jshint ignore:start */ 

    var keyStr = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz/='; 

    return { 
     encode: function (input) { 
      var output = ""; 
      var chr1, chr2, chr3 = ""; 
      var enc1, enc2, enc3, enc4 = ""; 
      var i = 0; 

      do { 
       chr1 = input.charCodeAt(i++); 
       chr2 = input.charCodeAt(i++); 
       chr3 = input.charCodeAt(i++); 

       enc1 = chr1 >> 2; 
       enc2 = ((chr1 & 3) << 4) | (chr2 >> 4); 
       enc3 = ((chr2 & 15) << 2) | (chr3 >> 6); 
       enc4 = chr3 & 63; 

       if (isNaN(chr2)) { 
        enc3 = enc4 = 64; 
       } else if (isNaN(chr3)) { 
        enc4 = 64; 
       } 

       output = output + 
        keyStr.charAt(enc1) + 
        keyStr.charAt(enc2) + 
        keyStr.charAt(enc3) + 
        keyStr.charAt(enc4); 
       chr1 = chr2 = chr3 = ""; 
       enc1 = enc2 = enc3 = enc4 = ""; 
      } while (i < input.length); 

      return output; 
     }, 

     decode: function (input) { 
      var output = ""; 
      var chr1, chr2, chr3 = ""; 
      var enc1, enc2, enc3, enc4 = ""; 
      var i = 0; 

      // remove all characters that are not A-Z, a-z, 0-9, +, /, or = 
      var base64test = /[^A-Za-z0-9\+\/\=]/g; 
      if (base64test.exec(input)) { 
       window.alert("There were invalid base64 characters in the input text.\n" + 
        "Valid base64 characters are A-Z, a-z, 0-9, '+', '/',and '='\n" + 
        "Expect errors in decoding."); 
      } 
      input = input.replace(/[^A-Za-z0-9\+\/\=]/g, ""); 

      do { 
       enc1 = keyStr.indexOf(input.charAt(i++)); 
       enc2 = keyStr.indexOf(input.charAt(i++)); 
       enc3 = keyStr.indexOf(input.charAt(i++)); 
       enc4 = keyStr.indexOf(input.charAt(i++)); 

       chr1 = (enc1 << 2) | (enc2 >> 4); 
       chr2 = ((enc2 & 15) << 4) | (enc3 >> 2); 
       chr3 = ((enc3 & 3) << 6) | enc4; 

       output = output + String.fromCharCode(chr1); 

       if (enc3 != 64) { 
        output = output + String.fromCharCode(chr2); 
       } 
       if (enc4 != 64) { 
        output = output + String.fromCharCode(chr3); 
       } 

       chr1 = chr2 = chr3 = ""; 
       enc1 = enc2 = enc3 = enc4 = ""; 

      } while (i < input.length); 

      return output; 
     } 
    }; 

    /* jshint ignore:end */ 
}); 

とfinalyこの:資産/ JavaScriptの/ appフォルダへ

'use strict'; 

// declare modules 
angular.module('Authentication', []); 
angular.module('Home', []); 

angular.module('BasicHttpAuthExample', [ 
    'Authentication', 
    'Home', 
    'ngRoute', 
    'ngCookies' 
]) 

.config(['$routeProvider', function ($routeProvider) { 

    $routeProvider 
     .when('/login', { 
      controller: 'LoginController', 
      templateUrl: 'modules/authentication/views/login.html', 
      hideMenus: true 
     }) 

     .when('/', { 
      controller: 'HomeController', 
      templateUrl: 'modules/home/views/home.html' 
     }) 

     .otherwise({ redirectTo: '/login' }); 
}]) 

.run(['$rootScope', '$location', '$cookieStore', '$http', 
    function ($rootScope, $location, $cookieStore, $http) { 
     // keep user logged in after page refresh 
     $rootScope.globals = $cookieStore.get('globals') || {}; 
     if ($rootScope.globals.currentUser) { 
      $http.defaults.headers.common['Authorization'] = 'Basic ' + $rootScope.globals.currentUser.authdata; // jshint ignore:line 
     } 

     $rootScope.$on('$locationChangeStart', function (event, next, current) { 
      // redirect to login page if not logged in 
      if ($location.path() !== '/login' && !$rootScope.globals.currentUser) { 
       $location.path('/login'); 
      } 
     }); 
    }]); 

、これと私のメインの中でそれらを参照:

と、これを追加
<script src="@routes.Assets.versioned("javascripts/app/controllers.js")" type="text/javascript"></script> 
    <script src="@routes.Assets.versioned("javascripts/app/services.js")" type="text/javascript"></script> 
    <script src="@routes.Assets.versioned("javascripts/app/app.js")" type="text/javascript"></script> 

私はこのすべてに慣れていませんもし私が何か他のものを逃してしまったのかどうかは分かりません。私が手 エラーは次のとおりです。

Use the function form of "use strict". 

答えて

0

関数内で "use strict"を使用してコードをラップするだけです。だからではなく、

"use strict"; 
angular.module('Authentication', []); 
angular.module('Home', []); 
// (...) 

使用この代わりに

(function() { 
    "use strict"; 
    angular.module('Authentication', []); 
    angular.module('Home', []); 
    // (...) 
})(); 

のまたJSHintが

/*jshint -W097 */ 
"use strict"; 

angular.module('Authentication', []); 
angular.module('Home', []); 
// (...) 
+0

があなたのリプレイをありがとうご説明いただきありがとうございます、そのエラーを無視することができます – Rajeun

0

「厳格な使用」の機能の形式を使用します。

"use strict"をファイルの最上位レベルのスコープに入れないように伝えようとしているものです。関数の中でを使用すると言います。あなたは、スコープ機能でコードをラップすることによって、トップとボトムラインを見ることを行うことができます。

(function() { // The beginning of the scoping function 'use strict'; angular.module('Authentication') .controller('LoginController', ['$scope', '$rootScope', '$location', 'AuthenticationService', function($scope, $rootScope, $location, AuthenticationService) { // reset login status AuthenticationService.ClearCredentials(); $scope.login = function() { $scope.dataLoading = true; AuthenticationService.Login($scope.username, $scope.password, function(response) { if (response.success) { AuthenticationService.SetCredentials($scope.username, $scope.password); $location.path('/'); } else { $scope.error = response.message; $scope.dataLoading = false; } }); }; } ]); })(); // The end of the function and the() to invoke it 

は今、その"use strict"のみ、その関数とその内容の中に適用されます。

+0

が – Rajeun