AngularJS: Protecting routes with angularjs depending if the user is authorized?

前端 未结 2 1120
无人及你
无人及你 2020-12-25 09:22

I have just started out working with an AngularJS app I\'m developing, everything is going well but I need a way of protecting routes so that a user wouldn\'t b

2条回答
  •  执笔经年
    2020-12-25 09:43

    Using resolves should help you out here: (code not tested)

    angular.module('app' []).config(function($routeProvider){
        $routeProvider
            .when('/needsauthorisation', {
                //config for controller and template
                resolve : {
                    //This function is injected with the AuthService where you'll put your authentication logic
                    'auth' : function(AuthService){
                        return AuthService.authenticate();
                    }
                }
            });
    }).run(function($rootScope, $location){
        //If the route change failed due to authentication error, redirect them out
        $rootScope.$on('$routeChangeError', function(event, current, previous, rejection){
            if(rejection === 'Not Authenticated'){
                $location.path('/');
            }
        })
    }).factory('AuthService', function($q){
        return {
            authenticate : function(){
                //Authentication logic here
                if(isAuthenticated){
                    //If authenticated, return anything you want, probably a user object
                    return true;
                } else {
                    //Else send a rejection
                    return $q.reject('Not Authenticated');
                }
            }
        }
    });
    

提交回复
热议问题