久久久久久久av_日韩在线中文_看一级毛片视频_日本精品二区_成人深夜福利视频_武道仙尊动漫在线观看

Django 中 cookie的使用

Cookie是瀏覽器在客戶端留下的一段記錄,這段記錄可以保留在內存或者硬盤上。Django里面,對cookie的讀取和設置很簡單。接下來通過本文給大家分享Django 中 cookie的使用,感興趣的朋友一

Cookie是瀏覽器在客戶端留下的一段記錄,這段記錄可以保留在內存或者硬盤上。因為Http請求是無狀態的,通過讀取cookie的記錄,服務器或者客戶端可以維持會話中的狀態。比如一個常見的應用場景就是登錄狀態。Django里面,對cookie的讀取和設置很簡單。Cookie本身的格式類似字典,因此可以通過request的key或者get獲取;然后他的設置則是通過response對象的set_cookie設定; 如果要取消cookie,把過期時間設置為當前時間就行了。

獲取Cookie:

request.COOKIES['key']
request.get_signed_cookie(key, default=RAISE_ERROR, salt='', max_age=None)
  參數:
    default: 默認值
    salt: 加密鹽
    max_age: 后臺控制過期時間

設置Cookie:

rep = HttpResponse(...) 或 rep = render(request, ...)
rep.set_cookie(key,value,...)
rep.set_signed_cookie(key,value,salt='加密鹽',...)
  參數:
    key,       鍵
    value='',     值
    max_age=None,   超時時間
    expires=None,   超時時間(IE requires expires, so set it if hasn't been already.)
    path='/',     Cookie生效的路徑,/ 表示根路徑,特殊的:跟路徑的cookie可以被任何url的頁面訪問
    domain=None,   Cookie生效的域名
    secure=False,   https傳輸
    httponly=False  只能http協議傳輸,無法被JavaScript獲取(不是絕對,底層抓包可以獲取到也可以被覆蓋)

例1  設置一個login登錄界面,一個index登錄成功之后的跳轉界面,如果沒有登錄那么自動跳轉到登錄界面

views.py

def index(reqeust):
  # 獲取當前已經登錄的用戶
  v = reqeust.COOKIES.get('username111')
  if not v:
    return redirect('/login/')
  return render(reqeust,'index.html',{'current_user': v})

注意Cookie的超時時間有2種方式,一個是直接指定max_age(N秒后超時),一個是指定expires后面跟一個具體的時間對象

httponly可以禁止JavaScript獲取這個值,但是實際上沒有什么鳥用,chrome或者抓包都能輕松獲取所有的cookie

index.html

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title></title>
</head>
<body>
  <h1>歡迎登錄:{{ current_user }}</h1>
</body>
</html>

login.html

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title></title>
</head>
<body>
  <form action="/login/" method="POST">
    <input type="text" name="username" placeholder="用戶名" />
    <input type="password" name="pwd" placeholder="密碼" />
    <input type="submit" />
  </form>
</body>
</html>

例2:

現實生活中,一般是把這個驗證cookie的功能寫成裝飾器,這樣直接在其他函數上面調用就行了

把例1改一下

def auth(func):
  def inner(reqeust,*args,**kwargs):
    v = reqeust.COOKIES.get('username111')
    if not v:
      return redirect('/login/')
    return func(reqeust, *args,**kwargs)
  return inner
@auth
def index(reqeust):
  # 獲取當前已經登錄的用戶
  v = reqeust.COOKIES.get('username111')
  return render(reqeust,'index.html',{'current_user': v})

例3: 我們知道可以使用fbv或者cbv來路由函數。例2使用了fbv的方式,用cbv也能實現

cbv里面,如果只打算裝飾一個方法,那么直接在方法前面加個@method_decorator就行;如果打算裝飾這個類里面所有的方法,那么在整個類的最上面進行裝飾

views.py

@method_decorator(auth,name='dispatch')
class Order(views.View):
  # @method_decorator(auth)
  # def dispatch(self, request, *args, **kwargs):
  #   return super(Order,self).dispatch(request, *args, **kwargs)
  # @method_decorator(auth)
  def get(self,reqeust):
    v = reqeust.COOKIES.get('username111')
    return render(reqeust,'index.html',{'current_user': v})
  def post(self,reqeust):
    v = reqeust.COOKIES.get('username111')
    return render(reqeust,'index.html',{'current_user': v})
urls.py
 url(r'^order/', views.Order.as_view()),

例4 我們還可以通過JavaScript或者JQuery來設置Cookie,比如在前面分頁的代碼基礎上,我們增加一個自定義顯示行數的功能。

user_list.html  這里下了一個JQuery的插件,這樣讀取設置cookie比較容易;而且,我們還限制了cookie的使用范圍,不是默認的所有范圍,而是僅僅局限于/user_list這個路徑里面

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title></title>
  <style>
    .go{
      width:20px;
       border: solid 1px;
      color: #66512c;
      display: inline-block;
      padding: 5px;
    }
    .pagination .page{
      border: solid 1px;
      color: #66512c;
      display: inline-block;
      padding: 5px;
      background-color: papayawhip;
      margin: 5px;
    }
    .pagination .page.active{
      background-color: brown;
      color: white;
    }
  </style>
</head>
<body>
  <ul>
    {% for item in li %}
      {% include 'li.html' %}
    {% endfor %}
  </ul>
  <div>
    <select id="ps" onchange="changePageSize(this)">
      <option value="10">10</option>
      <option value="30">30</option>
      <option value="50">50</option>
      <option value="100">100</option>
    </select>
  </div>
  <div class="pagination">
    {{ page_str }}
  </div>
  <script src="/static/jquery-1.12.4.js"></script>
  <script src="/static/jquery.cookie.js"></script>
  <script>
    $(function(){
        var v = $.cookie('per_page_count', {'path': "/user_list/`"});
        console.log(v)
        $('#ps').val(v);
    });
    function changePageSize(ths){
      var v = $(ths).val();
      console.log(v);
      $.cookie('per_page_count',v, {'path': "/user_list/"});     
      location.reload();
    }
  </script>
</body>
</html>
【網站聲明】本站除付費源碼經過測試外,其他素材未做測試,不保證完整性,網站上部分源碼僅限學習交流,請勿用于商業用途。如損害你的權益請聯系客服QQ:2655101040 給予處理,謝謝支持。

相關文檔推薦

1、PbootCMS后臺正常使用,ueditor編輯界面可以顯示, 但單圖片上傳按鈕點擊沒反應,多圖片上傳顯示后臺配置項返回格式出錯,上傳功能將不能正常使用! 2、打開瀏覽器調試模式,顯示
我們在用pbootcms時候,需要對一些數據進行統計,要怎么操作呢?其實pbootcms有一個sql語句標簽,通過這個標簽就可以實現。使用方法如下: {pboot:sql sql=語句}[sql:字段]{/pboot:sql} 我們這里
使用pb時發現標題這塊邏輯不太符合常用的效果,默認的是后臺有站點標題和副標題,在前臺的展示方式是: 1、首頁:站點標題-副標題 2、列表頁:欄目標題-站點標題-副標題 3、詳情
1、安裝前的準備工作: 1、本地安裝(在自己電腦上安裝測試)可以用集成包,wampserver,phpstudy(現在的小皮),安裝后請確保PHP版本在php5.4以上。 2、虛擬主機安裝,請選擇支持php+
本篇文章給大家詳細介紹了PHP開發接口使用RSA進行加密解密方法,對此有興趣的朋友可以學習下。
這篇文章主要介紹了PHP長連接實現與使用方法,結合實例形式較為詳細的分析了php長連接的概念、功能、實現與使用方法,需要的朋友可以參考下
主站蜘蛛池模板: 特一级毛片 | 一级片免费视频 | 免费在线观看h片 | 日韩久久久久 | 亚洲一区欧美 | 久久婷婷国产麻豆91 | 欧美日韩一区二区视频在线观看 | 在线不卡视频 | 综合国产 | 午夜免费观看 | www.亚洲视频| 日本精品久久久久 | 亚洲色图50p| 欧美精品一区二区三区在线 | 成人精品一区二区 | 国产精品久久久久久影视 | 精品一区二区三区在线观看国产 | 欧美日韩在线精品 | 999精品视频| 亚洲一区二区三区四区五区午夜 | 精品国产乱码久久久久久蜜臀 | 亚洲视频免费在线看 | 久久久国产精品一区 | 欲色av| 日本精品一区二区三区视频 | 免费在线观看一区二区三区 | 欧美专区日韩专区 | 国产亚洲精品久久久久久豆腐 | 久久久精品视频免费 | 亚洲色在线视频 | 国产美女在线免费观看 | 国产一区不卡 | 日韩福利在线 | 一本大道久久a久久精二百 国产成人免费在线 | 成人一区二区三区在线观看 | a级黄色毛片免费播放视频 国产精品视频在线观看 | 欧美午夜一区二区三区免费大片 | 国产精品美女久久久久久不卡 | 久久亚洲一区 | 亚洲人成人一区二区在线观看 | 国产精品五月天 |