国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

AngularJS實現用戶登錄狀態判斷的方法(Model添加攔截過濾器,路由增加限制)

2019-11-19 18:33:44
字體:
來源:轉載
供稿:網友

本文實例講述了AngularJS實現用戶登錄狀態判斷的方法。分享給大家供大家參考,具體如下:

使用AngularJS的單頁面應用時,由于是本地路由在控制頁面跳轉,但是有的時候我們需要判斷用戶是否登錄來判斷用戶是否能進入界面。

angularjs是mvc架構所以實現起來很容易也很靈活,我們只MainController里增加一個路由事件偵聽并判斷,這樣就可以避免未登錄用戶直接輸入路由地址來跳轉到登錄界面地址了

代碼中的 $rootScope.user是登錄后把用戶信息放到了全局rootScope上,方便其他地方使用,$rootScope.defaultPage也是默認主頁面,初始化的時候寫死到rootScope里的。

$rootScope.$on('$stateChangeStart',function(event, toState, toParams, fromState, fromParams){  if(toState.name=='login')return;// 如果是進入登錄界面則允許  // 如果用戶不存在  if(!$rootScope.user || !$rootScope.user.token){    event.preventDefault();// 取消默認跳轉行為    $state.go("login",{from:fromState.name,w:'notLogin'});//跳轉到登錄界面  }});

另外還有用戶已經登錄,但是登錄超時了,還有就是增加后臺接口的判斷來增強安全性。不能完全依靠本地邏輯

我們在model里面增加一個用戶攔截器,在rensponseError中判斷錯誤碼,拋出事件讓Contoller或view來處理

app.factory('UserInterceptor', ["$q","$rootScope",function ($q,$rootScope) {  return {    request:function(config){      config.headers["TOKEN"] = $rootScope.user.token;      return config;    },    responseError: function (response) {      var data = response.data;      // 判斷錯誤碼,如果是未登錄      if(data["errorCode"] == "500999"){        // 清空用戶本地token存儲的信息,如果        $rootScope.user = {token:""};        // 全局事件,方便其他view獲取該事件,并給以相應的提示或處理        $rootScope.$emit("userIntercepted","notLogin",response);      }      // 如果是登錄超時      if(data["errorCode"] == "500998"){        $rootScope.$emit("userIntercepted","sessionOut",response);      }      return $q.reject(response);    }  };}]);

別忘了要注冊攔截器到angularjs的config中哦

app.config(function ($httpProvider) {  $httpProvider.interceptors.push('UserInterceptor');});

最后在controller中處理錯誤事件

$rootScope.$on('userIntercepted',function(errorType){  // 跳轉到登錄界面,這里我記錄了一個from,這樣可以在登錄后自動跳轉到未登錄之前的那個界面  $state.go("login",{from:$state.current.name,w:errorType});});

最后還可以在loginController中做更多的細節處理

// 如果用戶已經登錄了,則立即跳轉到一個默認主頁上去,無需再登錄if($rootScope.user.token){  $state.go($rootScope.defaultPage);  return;}

另外在登錄成功回調后還可以跳轉到上一次界面,也就是上面記錄的from

var from = $stateParams["from"];$state.go(from && from != "login" ? from : $rootScope.defaultPage);

更多關于AngularJS相關內容感興趣的讀者可查看本站專題:《AngularJS入門與進階教程》及《AngularJS MVC架構總結

希望本文所述對大家AngularJS程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 安庆市| 格尔木市| 高碑店市| 昌江| 浙江省| 巢湖市| 延吉市| 中方县| 五华县| 济源市| 新乡市| 南和县| 广平县| 凯里市| 大余县| 南江县| 东光县| 绵竹市| 扎赉特旗| 通化县| 宜春市| 兴山县| 青神县| 惠州市| 济源市| 无锡市| 金门县| 长治县| 清水县| 南岸区| 青岛市| 涿州市| 大冶市| 南郑县| 沛县| 闵行区| 衡山县| 天全县| 化州市| 辽阳市| 华宁县|