哈尔滨+做网站公司有哪些,做外贸网站功能,包装设计网课答案,企业名Django视图#xff08;View#xff09;是Django Web框架中负责处理HTTP请求和返回HTTP响应的组件。视图是一段Python代码#xff0c;接收HTTP请求作为输入#xff0c;处理请求并返回HTTP响应作为输出。Django视图的主要目的是实现Web应用程序的业务逻辑#xff0c;将模型和… Django视图View是Django Web框架中负责处理HTTP请求和返回HTTP响应的组件。视图是一段Python代码接收HTTP请求作为输入处理请求并返回HTTP响应作为输出。Django视图的主要目的是实现Web应用程序的业务逻辑将模型和模板组合在一起生成最终的HTTP响应。 Django视图有很多种类型其中最常见的是基于函数的视图和基于类的视图。基于函数的视图非常简单且易于使用而基于类的视图提供了更多的功能和灵活性同时也更复杂一些。 在视图函数中你可以通过Django的模型层进行数据操作可以调用其他Python模块中的函数还可以调用Django的模板引擎来生成HTML响应。视图函数接受HTTP请求并可以从请求中获取参数和数据。在完成处理后视图函数将生成HTTP响应并将其发送回客户端。 视图函数通常可以通过装饰器来使用HTTP认证、缓存、请求限制等类似功能。Django还提供了一些内置的视图函数包括登录视图函数、重置密码视图函数等使得编写Web应用程序变得更加简单和高效。 视图函数 一个视图函数简称视图是一个简单的Python 函数它接受Web请求并且返回Web响应。响应可以是一张网页的HTML内容一个重定向一个404错误一个XML文档或者一张图片. . . 是任何东西都可以。无论视图本身包含什么逻辑都要返回响应。代码写在哪里也无所谓只要它在你的Python目录下面。除此之外没有更多的要求了——可以说“没有什么神奇的地方”。为了将代码放在某处约定是将视图放置在项目或应用程序目录中的名为views.py的文件中。 下面是一个返回当前日期和时间作为HTML文档的视图 from django.shortcuts import render, HttpResponse, HttpResponseRedirect, redirect
import datetimedef current_datetime(request):now datetime.datetime.now()html htmlbodyIt is now %s./body/html % nowreturn HttpResponse(html) 让我们逐行阅读上面的代码 首先我们从 django.shortcuts模块导入了HttpResponse类以及Python的datetime库。接着我们定义了current_datetime函数。它就是视图函数。每个视图函数都使用HttpRequest对象作为第一个参数并且通常称之为request。注意,视图函数的名称并不重要不需要用一个统一的命名方式来命名以便让Django识别它。我们将其命名为current_datetime是因为这个名称能够精确地反映出它的功能。这个视图会返回一个HttpResponse对象其中包含生成的响应。每个视图函数都负责返回一个HttpResponse对象。 三板斧的使用 HttpResponse: 字符串 render:渲染html页面 redirect:重定向的 在视图文件中写视图函数的时候不能没有返回值了默认返回的是None页面上就会报错 #源码def render(request, template_name, contextNone, content_typeNone, statusNone, usingNone):content loader.render_to_string(template_name, context, request, usingusing)return HttpResponse(content, content_type, status) HttpResponse() HttpResponse()括号内直接跟一个具体的字符串作为响应体比较直接很简单所以这里主要介绍后面两种形式。 render() render(request, template_name[, context] 结合一个给定的模板和一个给定的上下文字典并返回一个渲染后的 HttpResponse 对象。 参数 request 用于生成响应的请求对象。 template_name要使用的模板的完整名称可选的参数 context添加到模板上下文的一个字典。默认是一个空字典。如果字典中的某个值是可调用的视图将在渲染模板之前调用它。 render方法就是将一个模板页面中的模板语法进行渲染最终渲染成一个html页面作为响应体。 redirect() 传递要重定向的一个硬编码的URL def my_view(request):...return redirect(/some/url/)也可以是一个完整的URL def my_view(request):...return redirect(http://www.baidu.com/)响应状态码301和302 1301和302的区别。 301和302状态码都表示重定向就是说浏览器在拿到服务器返回的这个状态码后会自动跳转到一个新的URL地址这个地址可以从响应的Location首部中获取 用户看到的效果就是他输入的地址A瞬间变成了另一个地址B——这是它们的共同点。 他们的不同在于。301表示旧地址A的资源已经被永久地移除了这个资源不可访问了搜索引擎在抓取新内容的同时也将旧的网址交换为重定向之后的网址 302表示旧地址A的资源还在仍然可以访问这个重定向只是临时地从旧地址A跳转到地址B搜索引擎会抓取新的内容而保存旧的网址。 SEO302好于301 2重定向原因 1网站调整如改变网页目录结构 2网页被移到一个新地址 3网页扩展名改变(如应用需要把.php改成.Html或.shtml)。 这种情况下如果不做重定向则用户收藏夹或搜索引擎数据库中旧地址只能让访问客户得到一个404页面错误信息访问流量白白丧失再者某些注册了多个域名的 网站也需要通过重定向让访问这些域名的用户自动跳转到主站点等。 HttpRequest对象 request属性 django将请求报文中的请求行、首部信息、内容主体封装成 HttpRequest 类中的属性。 除了特殊说明的之外其他均为只读的 1.HttpRequest.GET一个类似于字典的对象包含 HTTP GET 的所有参数。详情请参考 QueryDict 对象。2.HttpRequest.POST一个类似于字典的对象如果请求中包含表单数据则将这些数据封装成 QueryDict 对象。POST 请求可以带有空的 POST 字典 —— 如果通过 HTTP POST 方法发送一个表单但是表单中没有任何的数据QueryDict 对象依然会被创建。因此不应该使用 if request.POST 来检查使用的是否是POST 方法应该使用 if request.method POST另外如果使用 POST 上传文件的话文件信息将包含在 FILES 属性中。注意键值对的值是多个的时候,比如checkbox类型的input标签select标签需要用request.POST.getlist(hobby)3.HttpRequest.body一个字符串代表请求报文的主体。在处理非 HTTP 形式的报文时非常有用例如二进制图片、XML,Json等。但是如果要处理表单数据的时候推荐还是使用 HttpRequest.POST 。4.HttpRequest.path一个字符串表示请求的路径组件不含域名。例如/music/bands/the_beatles/5.HttpRequest.method一个字符串表示请求使用的HTTP 方法。必须使用大写。例如GET、POST6.HttpRequest.encoding一个字符串表示提交的数据的编码方式如果为 None 则表示使用 DEFAULT_CHARSET 的设置默认为 utf-8。这个属性是可写的你可以修改它来修改访问表单数据使用的编码。接下来对属性的任何访问例如从 GET 或 POST 中读取数据将使用新的 encoding 值。如果你知道表单数据的编码不是 DEFAULT_CHARSET 则使用它。7.HttpRequest.META一个标准的Python 字典包含所有的HTTP 首部。具体的头部信息取决于客户端和服务器下面是一些示例取值CONTENT_LENGTH —— 请求的正文的长度是一个字符串。CONTENT_TYPE —— 请求的正文的MIME 类型。HTTP_ACCEPT —— 响应可接收的Content-Type。HTTP_ACCEPT_ENCODING —— 响应可接收的编码。HTTP_ACCEPT_LANGUAGE —— 响应可接收的语言。HTTP_HOST —— 客服端发送的HTTP Host 头部。HTTP_REFERER —— Referring 页面。HTTP_USER_AGENT —— 客户端的user-agent 字符串。QUERY_STRING —— 单个字符串形式的查询字符串未解析过的形式。REMOTE_ADDR —— 客户端的IP 地址。REMOTE_HOST —— 客户端的主机名。REMOTE_USER —— 服务器认证后的用户。REQUEST_METHOD —— 一个字符串例如GET 或POST。SERVER_NAME —— 服务器的主机名。SERVER_PORT —— 服务器的端口是一个字符串。从上面可以看到除 CONTENT_LENGTH 和 CONTENT_TYPE 之外请求中的任何 HTTP 首部转换为 META 的键时都会将所有字母大写并将连接符替换为下划线最后加上 HTTP_ 前缀。所以一个叫做 X-Bender 的头部将转换成 META 中的 HTTP_X_BENDER 键。8.HttpRequest.FILES一个类似于字典的对象包含所有的上传文件信息。FILES 中的每个键为input typefile name / 中的name值则为对应的数据。注意FILES 只有在请求的方法为POST 且提交的form 带有enctypemultipart/form-data 的情况下才会包含数据。否则FILES 将为一个空的类似于字典的对象。9.HttpRequest.COOKIES一个标准的Python 字典包含所有的cookie。键和值都为字符串。10.HttpRequest.session一个既可读又可写的类似于字典的对象表示当前的会话。只有当Django 启用会话的支持时才可用。完整的细节参见会话的文档。11.HttpRequest.user(用户认证组件下使用)一个 AUTH_USER_MODEL 类型的对象表示当前登录的用户。如果用户当前没有登录user 将设置为 django.contrib.auth.models.AnonymousUser 的一个实例。你可以通过 is_authenticated() 区分它们。例如if request.user.is_authenticated():# Do something for logged-in users.else:# Do something for anonymous users.user 只有当Django 启用 AuthenticationMiddleware 中间件时才可用。-------------------------------------------------------------------------------------匿名用户class models.AnonymousUserdjango.contrib.auth.models.AnonymousUser 类实现了django.contrib.auth.models.User 接口但具有下面几个不同点id 永远为None。username 永远为空字符串。get_username() 永远返回空字符串。is_staff 和 is_superuser 永远为False。is_active 永远为 False。groups 和 user_permissions 永远为空。is_anonymous() 返回True 而不是False。is_authenticated() 返回False 而不是True。set_password()、check_password()、save() 和delete() 引发 NotImplementedError。New in Django 1.8:新增 AnonymousUser.get_username() 以更好地模拟 django.contrib.auth.models.User。*/ request常用方法
1.HttpRequest.get_full_path()返回 path如果可以将加上查询字符串。例如/music/bands/the_beatles/?printtrue注意和path的区别http://127.0.0.1:8001/order/?namelqzage102.HttpRequest.is_ajax()如果请求是通过XMLHttpRequest 发起的则返回True方法是检查 HTTP_X_REQUESTED_WITH 相应的首部是否是字符串XMLHttpRequest。大部分现代的 JavaScript 库都会发送这个头部。如果你编写自己的 XMLHttpRequest 调用在浏览器端你必须手工设置这个值来让 is_ajax() 可以工作。如果一个响应需要根据请求是否是通过AJAX 发起的并且你正在使用某种形式的缓存例如Django 的 cache middleware你应该使用 vary_on_headers(HTTP_X_REQUESTED_WITH) 装饰你的视图以让响应能够正确地缓存。 JsonResponse 序列化 序列化json格式的数据
{a:1}json有什么用跨语言传输序列化:json.dumps
反序列化:json.loadsfrom django.http import JsonResponse
def index(request):# user_dict {username:kevin你好}user_dict [1, 2, 3, 4]# resjson.dumps(user_dict,ensure_asciiFalse)# return HttpResponse(res)# 通过看源码学技术# return JsonResponse(user_dict,json_dumps_params{ensure_ascii:False})return JsonResponse(user_dict,safeFalse)# return render(request,index.html)----------------------------------------------------------------------------------------# 第一种方式
# import json
# data{name:lqz,age:18}
# data1[lqz,egon]
# return HttpResponse(json.dumps(data1))
# 第二种方式
from django.http import JsonResponse
# data {name: lqz, age: 18}
data1 [lqz, egon]
# return JsonResponse(data)
return JsonResponse(data1,safeFalse)form表单上传文件 表单上传数据需要满足的条件 form action methodpost 1. 请求方式必须是post 2. enctypemultipart/form-data print(request.POST) # 接收的都是普通的数据非文件数据 # MultiValueDict: {myfile: [InMemoryUploadedFile: 234.png (image/png)]} print(request.FILES) # 只接受文件数据普通数据还在request.POST里面 简单文件上传 file_namerequest.FILES.get(file_name).name
from django.core.files.uploadedfile import InMemoryUploadedFile
with open(file_name,wb)as f:for i in request.FILES.get(file_name).chunks():f.write(i) def index(request):# user_dict {username:kevin你好}user_dict [1, 2, 3, 4]# resjson.dumps(user_dict,ensure_asciiFalse)# return HttpResponse(res)# 通过看源码学技术# return JsonResponse(user_dict,json_dumps_params{ensure_ascii:False})# return JsonResponse(user_dict,safeFalse)# return JsonResponse(user_dict,safeFalse)# QueryDict: {myfile: [234.png]}# QueryDict: {}print(request.POST)# MultiValueDict: {myfile: [InMemoryUploadedFile: 234.png (image/png)]}file_objrequest.FILES.get(myfile)# file_list file_obj.name.split(.) # 123.png# import uuid# random_strstr(uuid.uuid4())# file_name random_str file_obj.name.split(.)[-1]# with open(file_name, wb) as f:# for line in file_obj:# f.write(line)# print(request.body) # 接收纯原生的二进制数据没有任何的处理 b---- str----decode----dict...# print(request.POST.get()) # 之所以你能够直接按照字典的方式取值是因为django给做了封装print(request.path) # /index/ /index/print(request.path_info) # /index/ /index/print(request.get_full_path()) # /index/ /index/?a1b2print(request.GET.get())return render(request,index.html)CBV和FBV CBV基于类的视图(Class base view)和FBV基于函数的视图Function base view from django.views import Viewclass AddPublish(View):def dispatch(self, request, *args, **kwargs):print(request)print(args)print(kwargs)# 可以写类似装饰器的东西在前后加代码objsuper().dispatch(request, *args, **kwargs)return objdef get(self,request):return render(request,index.html)def post(self,request):requestreturn HttpResponse(post) CBV的源码解析 # 入口
url(r^login/, views.MyLogin.as_view()),# View类中得as_view方法的返回值是view函数名
# 当请求来的时候会触发view函数的执行def view(request, *args, **kwargs):# cls:Mylogin()------self对象self cls(**initkwargs)return self.dispatch(request, *args, **kwargs) # View类里的dispatchdef dispatch(self, request, *args, **kwargs):if request.method.lower() in self.http_method_names:handler getattr(self, request.method.lower(), self.http_method_not_allowed)else:handler self.http_method_not_allowedreturn handler(request, *args, **kwargs)from django.views import Viewclass MyLogin(View):http_method_names [get, post]def get(self, request):print(get。。。)self.index()return HttpResponse(get)def post(self, request):return HttpResponse(hello postman!!!)def index(self):pass权限、频率、jwt的源码模板层之模板变量 必须使用点语法 在Django中模板变量是指在模板中使用的动态数据。它们可以是Python对象的属性、方法、字典键和列表、元组或集合的元素等等。 下面是一些模板变量的示例 获取Python对象的属性 {{ object.attribute }}调用Python对象的方法 {{ object.method }}访问字典键 {{ dictionary.key }}访问列表、元组或集合的元素 {{ list.0 }}
{{ tuple.1 }}
{{ set.pop }}在模板中可以使用点号.点语法 来访问Python对象的属性和方法也可以使用中括号[]来访问字典的键或列表、元组或集合的元素。 在模板中还可以使用过滤器来对模板变量进行处理和格式化。例如使用date过滤器对日期进行格式化 {{ date|date:Y-m-d }}以上就是 Django 模板层之模板变量的相关内容。 {{ 写变量 }}
{% 写逻辑 %}{{ d.0 }}
{{ d.1 }}
{{ d.3 }}
{{ user_dict.hobby.2 }}
{{ index }}
{{ obj.score }}