一、视图概览
视图函数,简称视图,属于Django的视图层,默认定义在views.py文件中,是用来处理web请求信息以及返回响应信息的函数,所以研究视图函数只需熟练掌握两个对象即可:请求对象(HttpRequest
)和响应对象(HttpResponse
)。
当一个页面被请求时,Django 会创建一个 HttpRequest
对象,这个对象包含了请求的所有数据。然后,Django加载相应的视图,将 HttpRequest
对象作为视图函数的第一个参数传入,视图的形参习惯上命名为request
。每个视图负责返回一个 HttpResponse
对象。
二、HttpRequest对象
视图的第一个形参,也就是接收HttpRequest
对象的参数。习惯上命名为request
。
request.method
:提交表单所使用的方式,并其是全大写形式,如POST、GET等。
request.POST
:POST方式提交的数据,值为字典。
request.GET
:GET方式提交的数据,值为字典。
request.body
:二进制字符串形式的的请求体内容。
request.path
:只返回url的path部分,不包括其他部分。比如:/abc/xyz/
。
request.get_full_path()
:返回url的path部分,加上附加的查询字符串(如果有的话)。比如:/abc/xyz/?name=hugh&age=20
。
其他关于
HttpRequest
对象的方法和属性,可以查看文档:传送门
三、JsonResponse对象
JsonResponse类是一个HttpResponse类的子类,它接收一个字典数据,然后序列化为json数据发送到前端。
-
基本用法:
from django.http.response import JsonResponse def json_response(request): user_dict = { 'name': 'hugh', 'age': 20, 'height': 175, '爱好': '玩游戏!' } return JsonResponse(user_dict)
-
字符编码问题:
如果字典中含有非英文字符,
JsonResponse
会默认转换为UNICODE字符。解决方法如下:return JsonResponse(user_dict, json_dumps_params={'ensure_ascii':False})
JsonResponse()
的json_dumps_params参数,用来给json.dumps()
传参,所以将该参数设置为json_dumps_params={'ensure_ascii':False}
,即可解决字典被转换为UNICODE字符的问题。 -
其他数据类型的序列化:
JsonResponse()
默认只序列化字典对象,如果需要序列化其他对象,就需要将safe
参数设置为False。return JsonResponse(user_list, safe=False)
四、文件上传
request.POST
是无法获取用户上传的文件的,正确的获取方法是request.FILES
。
request.FILES
属性是一个类似字典的的对象,其中的键是 <input type="file" name="">
中的 name
属性值。
举例:
def gat_file(request):
# 获取文件对象
file_obj = request.FILES.get('file')
# 保存文件到项目根目录
with open(file_obj.name, 'wb') as f:
for line in file_obj.chunks():
f.write(line)
第6行的chunks([块的大小])
方法,用来分块读取文件内容,在文件特别大的时候,防止内存被占满。
五、FBV与CBV
django中,视图不仅可以基于函数实现,也可以基于类实现:
FBV(function base views) 基于函数的视图,就是在视图里使用函数处理请求。FBV我们之前一直在写,不做赘述。
CBV(class base views) 基于类的视图,就是在视图里使用类处理请求。
CBV的写法:
-
视图:
from django.views import View # Create your views here. class Index(View): def get(self, request): pass def post(self, request): pass
方法名对应请求方式,get请求方式就会使用对应的get方法。
-
路由:
from app01.views import Index urlpatterns = [ path('admin/', admin.site.urls), path('', Index.as_view(), name='index') ]
六、CBV添加装饰器
django不允许直接将装饰器加在方法上面,需要通过以下三种方法添加:
from django.views import View
from django.utils.decorators import method_decorator
# 方法一:传入装饰函数和被装饰方法
@method_decorator(装饰器函数, name='get')
@method_decorator(装饰器函数, name='post')
class MyView(View):
# 方法二:在被装饰方法上方
@method_decorator(装饰器函数)
def get(self, request):
pass
class MyView2(View):
# 方法三:装饰dispatch方法
@method_decorator(装饰器函数)
def dispatch(self, request, *args, **kwargs):
super().dispatch(request, *args, **kwargs)
pass
def get(self, request):
pass