前面我們介紹了cookies,主要應用在用戶登錄上,保存用戶登錄狀態,不過cookies直接放在了瀏覽器上,安全性較低,所以我們便引出了session功能與cookies相同,不同的是它放在了客戶端,相比較cookies來說安全性更高。還有分頁,這是一個比較常用的功能。
一、session
1、基本語法:
1、設置Sessions值 request.session['session_name'] ="admin"2、獲取Sessions值 session_name = request.session["session_name"] session_name = request.session.get("session_name")3、刪除Sessions值 del request.session["session_name"] request.session.flush()4、檢測是否操作session值 if "session_name" is request.session :2、解析圖

3、實例
1)views
def login(requset): if requset.method=="POST": username=requset.POST.get("user") password=requset.POST.get("pwd") ret=models.UserInfo.objects.filter(username=username,password=password) if ret: requset.session["IS_LOGON"]=True requset.session["USER"]=username return redirect("/home/") else: return redirect("/login/") return render(requset,"login.html")def home(request): ret=request.session.get("IS_LOGON",None) if ret : username=request.session.get("USER") return render(request, "home.html",locals()) else: return redirect("/login/")2)template
<form action="/login/" method="post"> {% csrf_token %} <p>姓名 <input type="text" name="user"></p> <p>密碼 <input type="password" name="pwd"></p> <input type="submit"></form>二、分頁
1、view
from django.shortcuts import render,HttpResponse# Create your views here.from app01.models import *from django.core.paginator import Paginator, EmptyPage, PageNotAnIntegerdef index(request): ''' 批量導入數據: Booklist=[] for i in range(100): Booklist.append(Book(title="book"+str(i),price=30+i*i)) Book.objects.bulk_create(Booklist) ''' '''分頁器的使用: book_list=Book.objects.all() paginator = Paginator(book_list, 10) print("count:",paginator.count) #數據總數 print("num_pages",paginator.num_pages) #總頁數 print("page_range",paginator.page_range) #頁碼的列表 page1=paginator.page(1) #第1頁的page對象 for i in page1: #遍歷第1頁的所有數據對象 print(i) print(page1.object_list) #第1頁的所有數據 page2=paginator.page(2) print(page2.has_next()) #是否有下一頁 print(page2.next_page_number()) #下一頁的頁碼 print(page2.has_previous()) #是否有上一頁 print(page2.previous_page_number()) #上一頁的頁碼 # 拋錯 #page=paginator.page(12) # error:EmptyPage #page=paginator.page("z") # error:PageNotAnInteger ''' book_list=Book.objects.all() paginator = Paginator(book_list, 10) page = request.GET.get('page',1) currentPage=int(page) try: print(page) book_list = paginator.page(page) except PageNotAnInteger: book_list = paginator.page(1) except EmptyPage: book_list = paginator.page(paginator.num_pages) return render(request,"index.html",{"book_list":book_list,"paginator":paginator,"currentPage":currentPage})
新聞熱點
疑難解答