亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

django認證系統(tǒng)實現(xiàn)自定義權(quán)限管理的方法

 更新時間:2019年08月28日 11:25:44   作者:le31ei  
今天小編就為大家分享一篇django認證系統(tǒng)實現(xiàn)自定義權(quán)限管理的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧

本文記錄使用django自帶的認證系統(tǒng)實現(xiàn)自定義的權(quán)限管理系統(tǒng),包含組權(quán)限、用戶權(quán)限等實現(xiàn)。

0x01. django認證系統(tǒng)

django自帶的認證系統(tǒng)能夠很好的實現(xiàn)如登錄、登出、創(chuàng)建用戶、創(chuàng)建超級用戶、修改密碼等復(fù)雜操作,并且實現(xiàn)了用戶組、組權(quán)限、用戶權(quán)限等復(fù)雜結(jié)構(gòu),使用自帶的認證系統(tǒng)就能幫助我們實現(xiàn)自定義的權(quán)限系統(tǒng)達到權(quán)限控制的目的。

0x02. 認證系統(tǒng)User對象

User對象顧名思義即為表示用戶的對象,里面的屬性包括:

username 
password 
email 
first_name 
last_name 
is_superuser 
is_active

創(chuàng)建好對象后,django會自動生成表,表名為auth_user,包含以上字段。具體的api文檔如下所示:

class models.User

User 對象具有如下字段:

username 
必選。少于等于30個字符。 用戶名可以包含字母、數(shù)字、_、@、+、.和- 字符。

first_name 
可選。 少于等于30個字符。

last_name 
可選。少于30個字符。

email 
可選。郵箱地址。

password 
必選。 密碼的哈希及元數(shù)據(jù)。(Django 不保存原始密碼)。原始密碼可以無限長而且可以包含任意字符。參見密碼相關(guān)的文檔。

groups 
與Group 之間的多對多關(guān)系。

user_permissions 
與Permission 之間的多對多關(guān)系。

is_staff 
布爾值。指示用戶是否可以訪問Admin 站點。

is_active 
布爾值。指示用戶的賬號是否激活。

is_superuser 
布爾值。只是這個用戶擁有所有的權(quán)限而不需要給他們分配明確的權(quán)限。

last_login 
用戶最后一次登錄的時間。

date_joined 
賬戶創(chuàng)建的時間。當賬號創(chuàng)建時,默認設(shè)置為當前的date/time。

一般在注冊操作中會用到該方法,實現(xiàn)注冊一個用戶,用到的函數(shù)是User.objects.create_user(),在新建用戶的時候需要判斷用戶是否存在,我的實現(xiàn)方式是,User.objects.get(username=xxx)去獲取一個用戶User對象,用try except實現(xiàn),如果用戶不存在則拋出User.DoesNotExist異常,在這個異常中進行創(chuàng)建用戶的操作。具體代碼如下:

# 注冊操作
from django.contrib.auth.models import User

try:
 User.objects.get(username=username)
 data = {'code': '-7', 'info': u'用戶已存在'}
except User.DoesNotExist:
 user = User.objects.create_user(username, email, password)
 if user is not None:
 user.is_active = False
 user.save()

該過程中密碼字段會自動加密存儲。無需關(guān)注過多細節(jié)。

0x03. 登錄登出用戶

創(chuàng)建好用戶后,就是登錄及登出了,django認證系統(tǒng)提供了login()及l(fā)ogout()函數(shù),能夠自動登錄登出,并且修改session值,非常方便。驗證用戶身份使用authenticate函數(shù)能自動進行password字段的hash比對。

具體實現(xiàn)代碼如下:

from django.contrib.auth import authenticate, login, logout

# 認證操作
ca = Captcha(request)
if ca.validate(captcha_code):
 user = authenticate(username=username, password=password)
 if user is not None:
 if user.is_active:
  # 登錄成功
  login(request, user) # 登錄用戶
  data = {'code': '1', 'info': u'登錄成功', 'url': 'index'}
 else:
  data = {'code': '-5', 'info': u'用戶未激活'}
 else:
  data = {'code': '-4', 'info': u'用戶名或密碼錯誤'}
else:
 data = {'code': '-6', 'info': u'驗證碼錯誤'}

登出操作如下:

from django.contrib.auth import authenticate, login, logout

def logout_system(request):
 """
 退出登錄
 :param request:
 :return:
 """
 logout(request)
 return HttpResponseRedirect('/')

0x04. login_required裝飾器

通過該裝飾器能夠使視圖函數(shù)首先判斷用戶是否登錄,如果未登錄會跳到默認在settings.py設(shè)置的LOGIN_URL參數(shù)對應(yīng)的url,如:LOGIN_URL = '/'。使用方法如下所示:

from django.contrib.auth.decorators import login_required

@login_required
def user_index(request):
 """
 用戶管理首頁
 :param request:
 :return:
 """
 if request.method == "GET":
  # 用戶視圖實現(xiàn)

0x05. 用戶組及權(quán)限分配

組對象包含的字段只有name,但是外鍵了幾張表,能夠與user、permissions,產(chǎn)生多對多的關(guān)系,我在自定義權(quán)限實現(xiàn)中,采用的是權(quán)限寫死的方法,添加用戶組權(quán)限。

創(chuàng)建組的函數(shù)采用Group.objects.create(name=xxx),就能實現(xiàn)了。當然也跟創(chuàng)建用戶一樣,需要先判斷是否組名已經(jīng)存在。

創(chuàng)建好組名后,下一步就需要為每個組分配權(quán)限了,從前端提交過來的權(quán)限列表,然后后端采用groups.permissions.add(permission)的方式依次將權(quán)限添加進組。

添加完組權(quán)限后,最后一步是將組名添加進用戶屬性,區(qū)分用戶屬于哪個組。

具體實現(xiàn)代碼如下:

# 創(chuàng)建組
try:
 Group.objects.get(name=role_name)
 data = {'code': -7, 'info': u'組名已存在'}
except Group.DoesNotExist:
 groups = Group.objects.create(name=role_name)
 if log_manage == 'true':
  permission = Permission.objects.get(codename='access_log')
  groups.permissions.add(permission)
 if role_manage == 'true':
  permission = Permission.objects.get(codename='access_role_manage')
  groups.permissions.add(permission)
 if user_manage == 'true':
  permission = Permission.objects.get(codename='access_user_manage')
  groups.permissions.add(permission)
 if get_users is not None:
  for user in get_users:
   # 每個user添加組屬性
   db_user = get_object_or_404(User, username=user)
   db_user.groups.add(groups)
   data = {'code': 1, 'info': u'添加成功'}
 return HttpResponse(json.dumps(data))

0x06. 權(quán)限模型及權(quán)限控制

在上一點中用到的Permission.objects.get(codename='access_user_manage')是通過權(quán)限模型創(chuàng)建,需要在models中創(chuàng)建一個權(quán)限類,然后在meta中進行定義codename。

class AccessControl(models.Model):
 """
 自定義權(quán)限控制
 """
 class Meta:
  permissions = (
   ('access_dashboard', u'控制面板'),
   ('access_log', u'日志管理'),
   ('access_role_manage', u'角色管理'),
   ('access_user_manage', u'用戶管理'),
  )

運行后,會自動在數(shù)據(jù)庫中創(chuàng)建相應(yīng)的表,并且插入數(shù)據(jù)。

在創(chuàng)建好權(quán)限之后,下一步就是在各個視圖中插入權(quán)限控制代碼了。permission_required(),參數(shù)為當前應(yīng)用名.codename。這樣就能控制用戶訪問,如果用戶非法訪問則會清空session退出登錄。

@permission_required('webcenter.access_role_manage')
@login_required
def role_index(request):
 """
 角色管理首頁
 :param request:
 :return:
 """

同時在前端模板頁面中也需要進行權(quán)限控制,前端要獲取request對象的話,后端返回就需要使用render函數(shù),render(request,xxx,xxx),具體代碼就如下:

{% if request.user.is_superuser or 'webcenter.access_user_manage' in request.user.get_group_permissions or 'webcenter.access_role_manage' in request.user.get_group_permissions or 'webcenter.access_log' in request.user.get_group_permissions %}
<li class="treeview">
 <a href="#" rel="external nofollow" rel="external nofollow" >
  <i class="fa fa-fw fa-skyatlas"></i>
  <span>站點管理</span> <i class="fa fa-angle-left pull-right"></i>
 </a>
 <ul class="treeview-menu">
 {% if request.user.is_superuser or 'webcenter.access_log' in request.user.get_group_permissions %}
  <li><a href="#" rel="external nofollow" rel="external nofollow" id="log_view">日志管理</a></li>
 {% endif %}
 {% if request.user.is_superuser or 'webcenter.access_role_manage' in request.user.get_group_permissions %}
  <li><a href="/role/index/" rel="external nofollow" >角色管理</a></li>
 {% endif %}
 {% if request.user.is_superuser or 'webcenter.access_user_manage' in request.user.get_group_permissions %}
  <li><a href="/user/index/" rel="external nofollow" >用戶管理</a></li>
 {% endif %}
</ul>
</li>
{% endif %}

以上這篇django認證系統(tǒng)實現(xiàn)自定義權(quán)限管理的方法就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • python基礎(chǔ)教程之udp端口掃描

    python基礎(chǔ)教程之udp端口掃描

    開發(fā)一個程序,用于獲取局域網(wǎng)中開啟snmp服務(wù)的主機ip地址列表,并寫入相應(yīng)文件以便其它程序使用。下面是實現(xiàn)方法
    2014-02-02
  • 基于python3 pyQt5 QtDesignner實現(xiàn)窗口化猜數(shù)字游戲功能

    基于python3 pyQt5 QtDesignner實現(xiàn)窗口化猜數(shù)字游戲功能

    這篇文章主要介紹了基于python3 pyQt5 QtDesignner實現(xiàn)窗口化猜數(shù)字游戲功能,本文通過實例代碼給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-07-07
  • Pandas聚合運算和分組運算的實現(xiàn)示例

    Pandas聚合運算和分組運算的實現(xiàn)示例

    這篇文章主要介紹了Pandas聚合運算和分組運算的實現(xiàn)示例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-10-10
  • Python無法安裝包的一種解決(Requirement already satisfied問題)

    Python無法安裝包的一種解決(Requirement already satisfied問題)

    這篇文章主要介紹了Python無法安裝包的一種解決(Requirement already satisfied問題),具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-08-08
  • 用Python進行基礎(chǔ)的函數(shù)式編程的教程

    用Python進行基礎(chǔ)的函數(shù)式編程的教程

    這篇文章主要介紹了用Python進行基礎(chǔ)的函數(shù)式編程的教程,除了面向?qū)ο缶幊桃馔狻ython還可以進行簡單的不依賴外部變量的函數(shù)式編程,本文介紹了其中的一些基礎(chǔ),需要的朋友可以參考下
    2015-03-03
  • python使用Flask框架獲取用戶IP地址的方法

    python使用Flask框架獲取用戶IP地址的方法

    這篇文章主要介紹了python使用Flask框架獲取用戶IP地址的方法,實例分析了Python使用Flask框架remote_addr獲取IP的技巧,非常具有實用價值,需要的朋友可以參考下
    2015-03-03
  • Python中pandas模塊DataFrame創(chuàng)建方法示例

    Python中pandas模塊DataFrame創(chuàng)建方法示例

    這篇文章主要介紹了Python中pandas模塊DataFrame創(chuàng)建方法,結(jié)合實例形式分析了DataFrame的功能,以及pandas模塊基于列表、字段與數(shù)組創(chuàng)建DataFrame的相關(guān)操作技巧,需要的朋友可以參考下
    2018-06-06
  • python讀取Dicom文件的示例詳解

    python讀取Dicom文件的示例詳解

    這篇文章通過示例代碼介紹了python讀取Dicom文件的方法,代碼簡單易懂,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友參考下吧
    2024-01-01
  • 從基礎(chǔ)到高階探索Python中的文件操作

    從基礎(chǔ)到高階探索Python中的文件操作

    文件操作在Python編程中是不可或缺的一部分,在本篇博客中,我們將全面、深入地探討Python中的文件操作,感興趣的小伙伴可以跟隨小編一起學習學習
    2023-06-06
  • Django中的用戶身份驗證示例詳解

    Django中的用戶身份驗證示例詳解

    這篇文章主要給大家介紹了關(guān)于Django中用戶身份驗證的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用SQL Django具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    2019-08-08

最新評論