ユーザーがログインしているかどうかを確認するために、ui-router と satellizer で angular を使用しています。これが私のコード例です:
var App = angular.module('myApp', ['satellizer', 'ui.router']);
App.config(function ($stateProvider, $urlRouterProvider) {
$urlRouterProvider.otherwise('/app/blank');
$stateProvider
.state('app', {
url: '/app',
abstract: true,
template: 'View<br><div ui-view=""></div>',
resolve: {
authorize: ['authService', function (authService) {
return authService.isLoggedin();
}]
}
})
.state('app.blank', {
url: '/blank',
title: 'Blank',
template: '<div>blank</div>'
})
.state('page', {
url: '/page',
template: 'Page<br><div ui-view=""></div>'
})
.state('page.login', {
url: '/login',
title: "Login",
template: 'Login'
});
});
App.factory('authService', function ($rootScope, $state, $auth) {
return {
isLoggedin: function () {
if (!$auth.isAuthenticated()) {
console.log('not logged in');
$state.go('page/login');
return true;
}
}
};
}
);
$stateProvider では、解決を使用して、ユーザーがログインしているかどうかを確認します。そうでない場合、スクリプトは状態ページ/ログインに移動する必要がありますが、そうではありません-単に動作を停止します。そのコードを修正するには?