11月在趕一個項目,這陣子比較忙,擠擠時間更一篇博客吧,如標題所述說說在ng中頁面訪問權限控制的問題,水平有限各位看官見諒;  

  在以往的項目中,前后端常見的配合方式是前端提供頁面和ui加一點DuangDuangDuang的效果,后端搭建框架數(shù)據(jù)結構和數(shù)據(jù)交互(數(shù)據(jù)交互前后端有交集),不管是.net、java or php都能一對多的提供前端服務,然而在新形式下項目中運用了前端框架,開發(fā)情況就不一樣了,比如我要說的這是在angular框架下完成的開發(fā),模式是后端提供服務和api文檔,頁面和數(shù)據(jù)交互及邏輯處理由前端完成,前端儼然是個完全的programer了,這個過程中就會遇到之前意想不到的問題(如果沒有做過后端開發(fā)),比如頁面權限控制,不得不說,使用前端的方式去做這些設置比較糾結,因為這方面的數(shù)據(jù),也就是這些權限的‘標示’,后端運行的時候是可以直接獲得的,即像獲取字段數(shù)據(jù)a.b點一下就出來了,而前端只能用http請求的方式獲取,繁瑣麻煩;

  其實在ng中做頁面訪問權有很多種方法,各有利弊,運用的比較多的是攔截器,攔截器使得在前端往后端發(fā)送http請求之前或之后做一些操作,比如全局監(jiān)測用戶是否登錄,沒登陸就要跳轉的登錄頁面,登錄就可以訪問頁面;攔截器的使用往往配合后臺數(shù)據(jù),也就是獲取到最新的‘標示’,來確定這個頁面或者下個頁面要做什么操作;而這里我使用的是一種用前端控制的方式,不用數(shù)據(jù)交互,理念就是定義好不同等級/階段可以訪問的頁面,在路由的地方作攔截,針對一些不同等級/階段訪問權限定義明確的可以參考使用這種方法,代碼如下:

移動開發(fā)培訓,Android培訓,安卓培訓,手機開發(fā)培訓,手機維修培訓,手機軟件培訓

'$rootScope', '$state', '$window', '$stateChangeStart', 
        Array.prototype.contains = (i  ([i] == needle)    status= Array("user.a","user.b","user.c","user.d","user.e","user.f","user.g" status0= Array("user.a","user.b" status1= Array("user.c","user.d" status2= Array("user.a","user.b","user.c","user.d"(initObj.getStatus()=="0"(!'user.approve'(ini
        
		

網友評論