国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Python > 正文

在Django的session中使用User對象的方法

2020-01-04 17:59:32
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了在Django的session中使用User對象的方法,Django是眾Python web開發框架中人氣最高的一個,需要的朋友可以參考下
 

通過session,我們可以在多次瀏覽器請求中保持數據, 接下來的部分就是用session來處理用戶登錄了。 當然,不能僅憑用戶的一面之詞,我們就相信,所以我們需要認證。

當然了,Django 也提供了工具來處理這樣的常見任務(就像其他常見任務一樣)。 Django 用戶認證系統處理用戶帳號,組,權限以及基于cookie的用戶會話。 這個系統一般被稱為 auth/auth (認證與授權)系統。 這個系統的名稱同時也表明了用戶常見的兩步處理。 我們需要

  •     驗證 (認證) 用戶是否是他所宣稱的用戶(一般通過查詢數據庫驗證其用戶名和密碼)
  •     驗證用戶是否擁有執行某種操作的 授權 (通常會通過檢查一個權限表來確認)
  • 根據這些需求,Django 認證/授權 系統會包含以下的部分:
  •     用戶 : 在網站注冊的人
  •     權限 : 用于標識用戶是否可以執行某種操作的二進制(yes/no)標志
  •     組 :一種可以將標記和權限應用于多個用戶的常用方法
  •     Messages : 向用戶顯示隊列式的系統消息的常用方法

如果你已經用了admin工具(詳見第6章),就會看見這些工具的大部分。如果你在admin工具中編輯過用戶或組,那么實際上你已經編輯過授權系統的數據庫表了。
打開認證支持

像session工具一樣,認證支持也是一個Django應用,放在 django.contrib 中,所以也需要安裝。 與session系統相似,它也是缺省安裝的,但如果它已經被刪除了,通過以下步驟也能重新安裝上:

  •     根據本章早前的部分確認已經安裝了session 框架。 需要確認用戶使用cookie,這樣sesson 框架才能正常使用。
  •     將 'django.contrib.auth' 放在你的 INSTALLED_APPS 設置中,然后運行 manage.py syncdb以創建對應的數據庫表。
  •     確認 SessionMiddleware 后面的 MIDDLEWARE_CLASSES 設置中包含 'django.contrib.auth.middleware.AuthenticationMiddleware' SessionMiddleware。

這樣安裝后,我們就可以在視圖(view)的函數中處理user了。 在視圖中存取users,主要用 request.user ;這個對象表示當前已登錄的用戶。 如果用戶還沒登錄,這就是一個AnonymousUser對象(細節見下)。

你可以很容易地通過 is_authenticated() 方法來判斷一個用戶是否已經登錄了:

?
1
2
3
4
if request.user.is_authenticated():
 # Do something for authenticated users.
else:
 # Do something for anonymous users.

使用User對象

User 實例一般從 request.user ,或是其他下面即將要討論到的方法取得,它有很多屬性和方法。 AnonymousUser 對象模擬了 部分 的接口,但不是全部,在把它當成真正的user對象 使用前,你得檢查一下 user.is_authenticated() 表14-3和14-4分別列出了`` User`` 對象中的屬性(fields)和方法。

在Django的session中使用User對象的方法

 


System Message: ERROR/3 (<string>, line 735)

Error parsing content block for the “table” directive: exactly one table expected.

.. table:: 表 ``User`` 對象方法

復制代碼代碼如下:

 

   +---------------------------------------------------------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------+
   |方法                                                                                         |描述                                                                                                                                                  |
   +=============================================================================================+======================================================================================================================================================+
   |``is_authenticated()``                                                                       |對于真實的User對象,總是返回/ `` True`` 。                                                                                                            |
   |                                                                                             |這是一個分辨用戶是否已被鑒證的方法。 它并不意味著任何權限,也不檢查用戶是否仍是活動的。 它僅說明此用戶已被成功鑒證。                                  |
   +---------------------------------------------------------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------+
   |``is_anonymous()``                                                                           |對于/ `` AnonymousUser`` 對象返回/ `` True`` (對于真實的/ `` User`` 對象返回/ `` False`` )。                                                        |
   |                                                                                             |總的來說,比起這個方法,你應該傾向于使用/ `` is_authenticated()`` 方法。                                                                              |
   +---------------------------------------------------------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------+
   |``get_full_name()``                                                                          |返回/ `` first_name`` 加上/ `` last_name`` ,中間插入一個空格。                                                                                       |
   +---------------------------------------------------------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------+
   |``set_password(passwd)``                                                                     |設定用戶密碼為指定字符串(自動處理成哈希串)。 實際上沒有保存/ ``User``/對象。                                                                        |
   +---------------------------------------------------------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------+
   |check_password(passwd)                                                                       |如果指定的字符串與用戶密碼匹配則返回/ ``True``/。 比較時會使用密碼哈希表。                                                                            |
   +---------------------------------------------------------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------+
   |``get_group_permissions()``                                                                  |返回一個用戶通過其所屬組獲得的權限字符串列表。                                                                                                        |
   +---------------------------------------------------------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------+
   |``get_all_permissions()``                                                                    |返回一個用戶通過其所屬組以及自身權限所獲得的權限字符串列表。                                                                                          |
   +---------------------------------------------------------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------+
   |``has_perm(perm)``                                                                           |如果用戶有指定的權限,則返回/ `` True`` ,此時/ `` perm`` 的格式是/ `` "package.codename"`` 。如果用戶已不活動,此方法總是返回/ `` False`` 。         |
   +---------------------------------------------------------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------+
   |has_perms(perm_list)                                                                         |如果用戶擁有/ * 全部* 的指定權限,則返回/ `` True`` 。 如果用戶是不活動的,這個方法總是返回/ `` False`` 。                                            |
   +---------------------------------------------------------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------+
   |``has_module_perms(app_label)``                                                              |如果用戶擁有給定的/ `` app_label`` 中的任何權限,則返回/ `` True`` 。如果用戶已不活動,這個方法總是返回/ `` False`` 。                                |
   +---------------------------------------------------------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------+
   |get_and_delete_messages()                                                                    |返回一個用戶隊列中的/ `` Message`` 對象列表,并從隊列中將這些消息刪除。                                                                               |
   +---------------------------------------------------------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------+
   |``email_user(subj, msg)``                                                                    |向用戶發送一封電子郵件。 這封電子郵件是從/ `` DEFAULT_FROM_EMAIL`` 設置的地址發送的。 你還可以傳送一個第三參數:/ `` from_email`` ,以覆蓋電郵中的發送地址。|
   +---------------------------------------------------------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------+

 

最后,`` User`` 對象有兩個many-to-many屬性。 `` groups`` 和`` permissions`` 。正如其他的many-to-many屬性使用的方法一樣,`` User`` 對象可以獲得它們相關的對象:
 

  1. # Set a user's groups: 
  2. myuser.groups = group_list 
  3.  
  4. # Add a user to some groups: 
  5. myuser.groups.add(group1, group2,...) 
  6.  
  7. # Remove a user from some groups: 
  8. myuser.groups.remove(group1, group2,...) 
  9.  
  10. # Remove a user from all groups: 
  11. myuser.groups.clear() 
  12.  
  13. # Permissions work the same way 
  14. myuser.permissions = permission_list 
  15. myuser.permissions.add(permission1, permission2, ...) 
  16. myuser.permissions.remove(permission1, permission2, ...) 
  17. myuser.permissions.clear() 
?

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 尚义县| 开鲁县| 壶关县| 民丰县| 贵州省| 耒阳市| 浑源县| 雷山县| 康保县| 德惠市| 新安县| 沙湾县| 克山县| 浠水县| 辰溪县| 苍梧县| 什邡市| 靖安县| 泰兴市| 枣强县| 天峻县| 淅川县| 田林县| 佛学| 胶州市| 鸡东县| 舟曲县| 洛宁县| 龙岩市| 安平县| 通城县| 张家港市| 策勒县| 穆棱市| 阳东县| 安多县| 芷江| 桃园县| 禹城市| 仙游县| 永嘉县|