Django2.0路由補充之path,re_path及視圖層


以下是Django2.0版本

正則捕獲到的參數都是字符串,所以如果函數需要用的其他數據類型,可以在函數中直接轉換,也可以在路由中直接轉換,如下:

下面實例是匹配整數,傳過去的參數就是整數

from django.urls import path,re_path

path('admin/<int:year>,view.year.archive') ===>匹配到一個整數變量

Django默認支持以下5個轉化器:

  • str,匹配除了路徑分隔符(/)之外的非空字符串,這是默認的形式
  • int,匹配正整數,包含0。
  • slug,匹配字母、數字以及橫杠、下划線組成的字符串。
  • uuid,匹配格式化的uuid,如 075194d3-6885-417e-a8a8-6c931e272f00。
  • path,匹配任何非空字符串,包含了路徑分隔符(/)(不能用問號,因為問號在url地址有特殊含義。)

1.path

path的第一個參數不能用正則

path其實就是封裝了五種精准的正則匹配(五個轉換器),我們也可以自己定義方法。===》(int,str,slug,path,uuid)

自定義轉換器:

  • regex 類屬性,字符串類型
  • to_python(self, value) 方法,value是由類屬性 regex 所匹配到的字符串,返回具體的Python變量值,以供Django傳遞到對應的視圖函數中。
  • to_url(self, value) 方法,和 to_python 相反,value是一個具體的Python變量值,返回其字符串,通常用於url反向引用。

1 寫一個類:
class Test:
  regex = '[0-9]{4}'
  def to_python(self, value):
  # 中間寫一堆處理
    value=value+'aaa'
    return value
  def to_url(self, value):  # 反向解析時候用到
    return '%04d' % value

 

# 和path,re_path在一個模塊里
2 from django.urls import register_converter

# 括號里跟兩個參數,第一個自定義的類 第二個是自定義的轉換器類型

register_converter 將其注冊到URL配置中
3 register_converter(Test,'ttt')
4 path('index/<ttt:year>', views.index,name='index'),

 

2.re_path

和Django1.1版本中的url用法相同,url地址可以用正則。

re_path (r'^admin/(?P<name>\w{3})$',views.admin)

 

 

二 MVC和MTV

MVC :M 模型     V  模板         C 控制器(路由+views)

MTV:M 模型      T  template V  views

 

三 視圖層

form表單,不寫method 默認GET請求

1 什么情況用GET :請求數據,請求頁面

1.什么情況用POST:向服務器提交數據,用GET會泄露數據,不懂技術的人也能看到

 

request.GET  得到的是一個封裝的字典:QueryDict

request.POST  得到的是一個封裝的字典:QueryDict

獲得請求的方式(類型):request.method

 

 http://127.0.0.1:8000/index/ppp/dddd/?name=lqz
 協議:ip地址和端口/路徑?參數(數據)

 print(request.path)   獲得的是不包括數據的請求
 print(request.get_full_path())  獲得的是整個url 包括數據請求

 

三件套:HttpResponse、redirect、render

from django.shortcuts import 三件套

 

JsonResponse(向前端頁面發送json格式字符串)

# dic={'name':'lqz','age':18}
# li=[1,2,3,4]
# # return HttpResponse(json.dumps(li))
# from django.http import JsonResponse

# 加safe是因為jsonResponse有安全保護不能直接向前端發送json格式字符串,所以要設置成False
# return JsonResponse(li,safe=False)

 

四 CBV(class base view)和FBV(function base view)

CBV 和FBV基於類的視圖和基於函數的視圖

CBV:

1 from django.views import View
2 class Test(View):
  def dispatch(self, request, *args, **kwargs):
  # 加點東西
    print('111')

    obj=super().dispatch(request, *args, **kwargs)
  # 加點東西
    print('2222')
    return obj
  def get(self,request):
    obj= render(request,'index.html')
    print(type(obj))
    return obj
  def post(self,request):
    return HttpResponse('ok')


3 re_path(r'index/', views.Test.as_view()), # 這兒是固定寫法

 

簡單文件上傳

index.html
1 <form action="" method="post" enctype="multipart/form-data">
用戶名:<input type="text" name="name">
密碼:<input type="text" name="password">
文件:<input type="file" name="myfile">
<input type="submit">

</form>
#enctype="multipart/form-data"*******************  這個是上傳文件必須要加的
#<input type="file" name="myfile">  # 如果寫了這個enctype但是沒有上傳文件,打印的request.FILES.get()會有瀏覽器配置等內容。

2 # ff是一個文件對象,django封裝的
ff=request.FILES.get('myfile')
# 文件對象的名字
file_name=ff.name # 上傳的文件名字。
from django.core.files.uploadedfile import InMemoryUploadedFile  # 導入這個類 chunks是這個類的方法
print(type(ff))
with open(file_name,'wb') as f:  # chunks是一個生成器,通過yield不斷把值給讀出來。
  for line in ff.chunks():  # chunks是文件對象的方法,相當於斷點續傳。為什么不能直接in ff:直接寫入:因為ff是一個對象,不是一個文件
    f.write(line)

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM