django 通过url实现简单的权限控制

根据用户权限设定用户可以访问哪些页面,用django实现一个简单的demo。

1.models.py 文件

class level(models.Model):
    l_name = models.CharField(max_length=50,verbose_name="等级名称")
    l_permission = models.OneToOneField("permission")
    def __str__(self):
        return self.l_name


class userinfo(models.Model):
    u_name = models.CharField(max_length=50,verbose_name="用户名称")
    u_user = models.OneToOneField(User)
    u_level = models.ForeignKey(level,related_name="lev")

    def __str__(self):
        return self.u_name


class permission(models.Model):
    p_name = models.CharField(max_length=50,verbose_name="权限名称")
    p_menu = models.ManyToManyField("menu")

    def __str__(self):
        return self.p_name

class menu(models.Model):
    m_name = models.CharField(max_length=50,verbose_name="菜单名称")
    m_url = models.CharField(max_length=50,verbose_name="菜单地址",blank=True,null=True)
    def __str__(self):
        return self.m_name

class nickname(models.Model):
    n_nickname = models.CharField(max_length=50,verbose_name="昵称",blank=True,null=True)
    n_user = models.ForeignKey(userinfo,blank=True,null=True,related_name="nick")

    def __str__(self):
        return self.n_nickname

设置用户及角色的关系,可访问的路由。

2.settings.py 文件

URL_WHITE_LIST = ['index', 'login', 'logout']

设置路由白名单。

3.views.py 文件

def url_check(fun):
    def check(request,*args,**kwargs):
        if request.session.get("p_l",None):
            require_list = pickle.loads(request.session.get("p_l"))
            request_url = request.path.replace("/","")
            ua = request.META.get('HTTP_USER_AGENT',None)
            if request_url in require_list or request_url in IP_WHITE_LIST:
                return fun(request,*args,**kwargs)
            else:
                error_msg = "没有权限!"
                menu_ = pickle.loads(request.session.get("p_l"))
                return render(request,"index.html",{"error_msg":error_msg,"menu":menu_})
        else:
            return HttpResponseRedirect(reverse("login"))
    return check

定义一个路由检测的闭包方法,根据用户登录时的session信息,获取该用户角色可以访问的路由,如果当前访问的地址不在白名单或是session记录里,返回错误信息。

@url_check
def menu(request,menuname):
    return HttpResponse("<h1>%s</h1>"%menuname)

在之后的方法上添加该闭包,即可实现简易的路由控制。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值