作家
登录

前端真的能做到彻底权限控制吗?

作者: 来源: 2018-01-05 12:08:36 阅读 我要评论

【限时免费】岁尾最强一次云计算大年夜会,看传统、社区、互联网企业若何碰撞?


前端真的能做到彻底权限控制吗?

有一天忽然想到一个问题,web端的权限控制:

1.真的能控制权限吗?

3.如不雅须要后台合营,应当若何合营?

可能这是一个老生常谈的问题,但照样想整顿下,有误的处所望大年夜家指出。

浏览器http header

权限控制大年夜致分为两个维度:

  • 垂直维度: 控制用户可以拜访哪些url的权限
  • 程度维度: 控制用户拜访特定url,获取哪些数据的权限(e.g. 通俗用户、治理员、超等治理员拜访同一url,获取的数据是不合的) 

Web权限控制筹划List

  • 前后端不分别:以Java为例,后端经由过程jsp、freemark、thmeleaf等模板来衬着响应权限的数据,衬着完涌如今浏览器端 
  • 前后端分别:
    • SPA单页面应用,路由由前端控制,前端经由过程js控制hash路由的权限
    • SSR办事端衬着,Node中心层做代劳路由,断定权限衬着特定的路由至浏览器端 

SPA前端权限控制筹划

SPA: 单页Web应用(single page web application)将所有web晃荡局限于一个html页面中,应用js经由过程hash或者浏览器history api来实现无刷新路由跳转,前后端经由过程ajax数据通信,避免了浏览器的刷新从新加载,为用户供给流程的操作体验。这意味着前端接收了路由层,须要经由过程调用前端自身的MVC模块,来衬着不合的页面。

Base>

  • // 1.触发上岸事宜 
  •  
  • dispatch('login')  
  •  
  • // actions 
  •  
  • commit(types.LOGIN_SUCCESS, res.data.data) 
  •  
  • ...  
    1. // mutations 
    2.  
    3. const mutations = { 
    4.  
    5.     [types.LOGIN_SUCCESS] (state, data) { 
    6.  
    7.         state.authlock = false 
    8.  
    9.     // 2.上岸成功回调拿到token,经Base64 编码后存入本地sessionStorage 
    10.  
    11.         let token = Base64.encode(data + ':HIKDATAE'
    12.  
    13.         sessionStorage.setItem('userToken', token) 
    14.  
    15.     // 路由跳转至目标页面 
    16.  
    17.         router.push({name'xxx'}) 
    18.  
    19.     }, 
    20.  
    21.     [types.LOGOUT_SUCCESS] (state) { 
    22.  
    23.         state.authlock = true 
    24.  
    25.     // 登出成功回调,移除本地token 
    26.  
    27.         sessionStorage.removeItem('userToken'
    28.  
    29.         router.push({name'Login'}) 
    30.  
    31.     } 
    32.  
    33.  

    3.所有HTTP Header Authorization 加上编码后的token(前后端可商定规矩) 

    2.仅仅靠前端,能不克不及做到真正的权限控制?


        推荐阅读

        服务器为什么要做磁盘阵列?

      【限时免费】岁尾最强一次云计算大年夜会,看传统、社区、互联网企业若何碰撞? 有同伙留言欲望我们能发一期关>>>详细阅读


      本文标题:前端真的能做到彻底权限控制吗?

      地址:http://www.17bianji.com/lsqh/40263.html

    关键词: 探索发现

    乐购科技部分新闻及文章转载自互联网,供读者交流和学习,若有涉及作者版权等问题请及时与我们联系,以便更正、删除或按规定办理。感谢所有提供资讯的网站,欢迎各类媒体与乐购科技进行文章共享合作。

    网友点评
    自媒体专栏

    评论

    热度

    精彩导读
    栏目ID=71的表不存在(操作类型=0)