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

首頁 > 編程 > Python > 正文

在Python的Django框架的視圖中使用Session的方法

2020-01-04 17:59:41
字體:
來源:轉載
供稿:網友

這篇文章主要介紹了在Python的Django框架的視圖中使用Session的方法,包括相關的設置測試Cookies的方法,需要的朋友可以參考下

SessionMiddleware 激活后,每個傳給視圖(view)函數的第一個參數``HttpRequest`` 對象都有一個 session 屬性,這是一個字典型的對象。 你可以象用普通字典一樣來用它。 例如,在視圖(view)中你可以這樣用:

 

 
  1. # Set a session value: 
  2. request.session["fav_color"] = "blue" 
  3.  
  4. # Get a session value -- this could be called in a different view, 
  5. # or many requests later (or both): 
  6. fav_color = request.session["fav_color"
  7.  
  8. # Clear an item from the session: 
  9. del request.session["fav_color"
  10.  
  11. # Check if the session has a given key: 
  12. if "fav_color" in request.session: 
  13. ... 

其他的映射方法,如 keys() 和 items() 對 request.session 同樣有效:

下面是一些有效使用Django sessions的簡單規則:

用正常的字符串作為key來訪問字典 request.session , 而不是整數、對象或其它什么的。

Session字典中以下劃線開頭的key值是Django內部保留key值。 框架只會用很少的幾個下劃線 開頭的session變量,除非你知道他們的具體含義,而且愿意跟上Django的變化,否則,最好 不要用這些下劃線開頭的變量,它們會讓Django攪亂你的應用。

比如,不要象這樣使用`` _fav_color`` 會話密鑰(session key):

 

 
  1. request.session['_fav_color'] = 'blue' # Don't do this

不要用一個新對象來替換掉 request.session ,也不要存取其屬性。 可以像Python中的字典那樣使用。 例如:

 

 
  1. request.session = some_other_object # Don't do this
  2.  
  3. request.session.foo = 'bar' # Don't do this

我們來看個簡單的例子。 這是個簡單到不能再簡單的例子:在用戶發了一次評論后將has_commented設置為True。 這是個簡單(但不很安全)的、防止用戶多次評論的方法。

 

 
  1. def post_comment(request): 
  2. if request.method != 'POST'
  3. raise Http404('Only POSTs are allowed'
  4.  
  5. if 'comment' not in request.POST: 
  6. raise Http404('Comment not submitted'
  7.  
  8. if request.session.get('has_commented', False): 
  9. return HttpResponse("You've already commented."
  10.  
  11. c = comments.Comment(comment=request.POST['comment']) 
  12. c.save() 
  13. request.session['has_commented'] = True 
  14. return HttpResponse('Thanks for your comment!'

下面是一個很簡單的站點登錄視圖(view):

 

 
  1. def login(request): 
  2. if request.method != 'POST'
  3. raise Http404('Only POSTs are allowed'
  4. try
  5. m = Member.objects.get(username=request.POST['username']) 
  6. if m.password == request.POST['password']: 
  7. request.session['member_id'] = m.id 
  8. return HttpResponseRedirect('/you-are-logged-in/'
  9. except Member.DoesNotExist: 
  10. return HttpResponse("Your username and password didn't match."

下面的例子將登出一個在上面已通過`` login()`` 登錄的用戶:

 

 
  1. def logout(request): 
  2. try
  3. del request.session['member_id'
  4. except KeyError: 
  5. pass 
  6. return HttpResponse("You're logged out."

注意

在實踐中,這是很爛的用戶登錄方式,稍后討論的認證(authentication )框架會幫你以更健壯和有利的方式來處理這些問題。 這些非常簡單的例子只是想讓你知道這一切是如何工作的。 這些實例盡量簡單,這樣你可以更容易看到發生了什么

設置測試Cookies

就像前面提到的,你不能指望所有的瀏覽器都可以接受cookie。 因此,為了使用方便,Django提供了一個簡單的方法來測試用戶的瀏覽器是否接受cookie。 你只需在視圖(view)中調用 request.session.set_test_cookie(),并在后續的視圖(view)、而不是當前的視圖(view)中檢查 request.session.test_cookie_worked() 。

雖然把 set_test_cookie() 和 test_cookie_worked() 分開的做法看起來有些笨拙,但由于cookie的工作方式,這無可避免。 當設置一個cookie時候,只能等瀏覽器下次訪問的時候,你才能知道瀏覽器是否接受cookie。

檢查cookie是否可以正常工作后,你得自己用 delete_test_cookie() 來清除它,這是個好習慣。 在你證實了測試cookie已工作了之后這樣操作。

這是個典型例子:

 

 
  1. def login(request): 
  2.  
  3. # If we submitted the form... 
  4. if request.method == 'POST'
  5.  
  6. # Check that the test cookie worked (we set it below): 
  7. if request.session.test_cookie_worked(): 
  8.  
  9. # The test cookie worked, so delete it. 
  10. request.session.delete_test_cookie() 
  11.  
  12. # In practice, we'd need some logic to check username/password 
  13. # here, but since this is an example... 
  14. return HttpResponse("You're logged in."
  15.  
  16. # The test cookie failed, so display an error message. If this 
  17. # were a real site, we'd want to display a friendlier message. 
  18. else
  19. return HttpResponse("Please enable cookies and try again."
  20.  
  21. # If we didn't post, send the test cookie along with the login form. 
  22. request.session.set_test_cookie() 
  23. return render_to_response('foo/login_form.html'

注意

再次強調,內置的認證函數會幫你做檢查的。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 平凉市| 深州市| 正阳县| 陇西县| 宁德市| 阿鲁科尔沁旗| 澜沧| 浠水县| 治多县| 平陆县| 舞阳县| 临夏县| 洪雅县| 北海市| 滨海县| 东宁县| 临安市| 大连市| 西乡县| 保山市| 屏边| 广丰县| 玛多县| 灵宝市| 开阳县| 怀柔区| 莒南县| 庆元县| 苍溪县| 桃园县| 东台市| 汶上县| 沅江市| 凯里市| 谷城县| 建水县| 合肥市| 长宁县| 乾安县| 汨罗市| 加查县|