标签:ack bubuko 显示 log 用户名 migrate ima pwd ext
INSTALLED_APPS = [ ... ... ‘crm.apps.CrmConfig‘, "stark.apps.StarkConfig", ‘rbac.apps.RbacConfig‘, ]
MIDDLEWARE = [ 。。。。 ‘rbac.service.rbac.ValidPermission‘, ]
UserInfo中的用户名和密码也可删了,只留rbac.User中的用户名和密码。
user= models.OneToOneField(to=User,null=True,on_delete=True)
from stark.service.stark import site,ModelStark from .models import * class UserConfig(ModelStark): list_display = [‘name‘,‘roles‘] site.register(User,UserConfig) site.register(Role) class PermissionConfig(ModelStark): list_display = [‘id‘,‘title‘,‘url‘,‘group‘,‘action‘] site.register(Permission,PermissionConfig) site.register(PermissionGroup)
、
from django.conf.urls import url from django.contrib import admin from crm import views from stark.service.stark import site urlpatterns = [ url(r‘^admin/‘, admin.site.urls), url(r‘^stark/‘, site.urls), url(r‘^login/‘, views.login), ]
from django.shortcuts import render,HttpResponse # Create your views here. from rbac.models import User from rbac.service.perssions import initial_session def login(request): if request.method ==‘POST‘: user = request.POST.get(‘user‘) pwd = request.POST.get(‘pwd‘) user = User.objects.filter(name=user,pwd=pwd).first() if user: request.session[‘user_id‘]=user.pk # 注册权限到session中 initial_session(request,user) return HttpResponse(‘登录成功‘) return render(request,‘login.html‘,locals())
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> </head> <body> <form action="" method="post"> {% csrf_token %} 用户名: <input type="text" name="user"> 密码: <input type="password" name="pwd"> <input type="submit"> </form> </body> </html>
MIDDLEWARE = [ 。。。 ‘rbac.service.rbac.ValidPermission‘, ]
# 注册菜单权限 # permissions = user.roles.all().values("permissions__url", "permissions__action", "permissions__group__title").distinct() permissions = user.roles.all().values("permissions__url", "permissions__action", "permissions__title").distinct() # menu_permission_list.append((item["permissions__url"], item["permissions__group__title"])) # 组的名称 menu_permission_list.append((item["permissions__url"], item["permissions__title"])) # 用自己permission的title
例如:chang_view.html
{% extends ‘base.html‘ %} {% block content %} <h3>编辑页面</h3> {% include ‘form.html‘ %} {% endblock %}
例如base.html
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> <link rel="stylesheet" href="/static/bootstrap/css/bootstrap.css"> <script src="/static/js/jquery-1.12.4.min.js"></script> <script src="/static/charts/highcharts.js"></script> <link rel="stylesheet" href="/static/css/add.css"> <link rel="stylesheet" href="/static/css/list.css"> <link rel="stylesheet" href="/static/css/base.css"> </head> <body> <div class="header"> <span style="background-color: azure">{{ user.name }}</span> </div> <div class="container"> {% load my_tags %} <div class="menu left"> {% get_menu request %} </div> <div class="content right"> {% block content %} {% endblock %} </div> </div> </body> </html>
github代码 https://github.com/venicid/CRM_low
标签:ack bubuko 显示 log 用户名 migrate ima pwd ext
原文地址:https://www.cnblogs.com/venicid/p/9584530.html