计算机基础知识61

JsonResponse 功能例子

你自己写一个类,实现JsonResponse 功能,不需要传safe=False,无论字典或列表,都能完成序列化返回给前端

1

响应头例子

四种情况,在响应头返回数据  xx=xx
 # 第一种情况 JsonResponse

def show(request):
# 方式一return JsonResponse({'fjw': 123}, headers={'xx': 'xx'})
# 方式二 # 后面headers可以同时用  也可以删掉res = JsonResponseres['name'] = 'glwnnb'return res

# 第二种情况 HttpResponse

def show(request):
# 方式一res = HttpResponse('123')res.set_cookie('name', 'genglianwen')
# 方式二res = HttpResponse('123')res['name'] = 'glwnb'return res

# 第三种情况 Redirect

def show(request):res = redirect("/admin/")res['lw'] = 'i am geng lianwen'return res

# 第四种情况 render

def show(request):res = render(request, 'up_image.html')res['name'] = 'glw'return res
t = Template('<html><body>:<h1>{{name}}nb </h1></body></html>

面向对象绑定给类方法例子

绑定给类的方法,类来调用,对象可以调用吗?如何用

# 加一个装饰器@classmethod,把方法的第一个形参改为cls

  会把类自动当成第一个参数传递给方法的第一个形参cls

可以调用

class MyClass:@classmethoddef index(cls):     # cls:就是类print("hello index")
obj = MyClass()
obj.index()    # hello index

面向对象绑定给对象方法例子

绑定给对象的方法,对象来调用,类可以调用吗?如何用

#  默认情况下,在类内部写方法是绑定给对象的,就有对象来调用,就会自动来传递参数

         绑定给对象的方法,类也能调用,但是方法中需要传递几个就要传几个,包括self

class Student():school = 'SH'def __init__(self, name, age, gender):self.name = nameself.age = ageself.gender = genderdef tell_info(self, username, password):print("name:%s  %s %s" % (self.name, username, password))
stu = Student('ly', 20, 'male')
stu.tell_info('kevin', 123)             # self自动来传递参数
Student.tell_info(stu , 'kevin' ,123)   # 需要传递几个就要传几个,包括self

上传文件例子

写个图片上传功能,图片保存在根路径media文件夹下

        上传成功直接在前端显示出上传的图片

setting.py
import os
TEMPLATES = ['DIRS': [os.path.join(BASE_DIR,'templates')]]MEDIA_URL = '/media/'
MEDIA_ROOT = os.path.join(BASE_DIR,'media')
urls.py
from django.contrib import admin
from django.urls import path,re_path
from django.conf.urls import static
from django.conf import settings
from django.views.static import serve
from app01 import viewsurlpatterns = [path('admin/', admin.site.urls),path('tupian/', views.FileView.as_view()),re_path('media/(?P<path>.*)', serve, {'document_root': settings.MEDIA_ROOT}),
]
views.py
from django.shortcuts import render, HttpResponse
# Create your views here.
from django.views import Viewclass FileView(View):def get(self, request):return render(request, 'tupian.html')def post(self, requst):# 拿出文件# {'mytupian': [<InMemoryUploadedFile: 1701262155217.jpg (image/jpeg)>]}my_tupian = requst.FILES.get('mytupian')# print(my_tupian.name)import osbasr_dir = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))dizi = os.path.join(basr_dir, 'media', my_tupian.name)with open(my_tupian.name, 'wb') as f:with open(dizi, 'wb') as f1:for line in my_tupian:f1.write(line)return render(requst,'tupian.html',locals())
tupian.html
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Title</title>
</head>
</head>
<body>
<form action="" method="post" enctype="multipart/form-data"><input type="file" name="mytupian"><br><input type="submit" value="提交">
</form>
{#前端展示#}
<div>{% if my_tupian %}<img src="../media/{{ my_tupian.name }}" alt="">{% endif %} 
</div>
</body>
</html>

for标签例子

建个表---》插入100条数据---》写个页面,for循环把100条数据显示在页面上

2、

3、

过滤器例子

   (能做就做)自定义一个过滤器---》实现 

 数据有个表---》content字段---》别人存入了一些敏感词
        你这个大[傻逼]
        它[妈的]
        
    模板显示:content 
    {{content|pingbi}}
    你这个大**
    它**
    
    高级一些:关键词放到一个列表中,可以随时增加,不需要重启项目---》数据可以放在数据库中

2、

3、

视图层补充:响应对象

# 响应的本质都是 HttpResponse,是字符串    

render:放个模板,模板语法是在后端执行的
redirect:重定向,字符串参数不是是空的,状态码是 3开头
JsonResponse:json格式数据,如果想往响应头中写数据,需要传headers={'xx':'xx'}
js代码:在客户端浏览器里执行的

# JsonResponse源码分析:

return JsonResponse({name:lqz,age:19})     
# 触发  JsonResponse的__init__--->{name:lqz,age:19}给了data
def __init__(self, data, encoder=DjangoJSONEncoder, safe=True,json_dumps_params=None, **kwargs):# 如果传入的四字典# safe是True,后面是False,条件不符合,内部就不会走# isinstance(对象, 类) 判断这个对象,是不是这个类的对象if safe and not isinstance(data, dict):raise TypeError('In order to allow non-dict objects to be serialized set the ''safe parameter to False.')if json_dumps_params is None: # 条件符合json_dumps_params = {}# kwargs是字典---》setdefault--》有则修改,无则新增kwargs.setdefault('content_type', 'application/json')# 核心---》把字典转成json格式字符串,赋值给datadata = json.dumps(data, cls=encoder, **json_dumps_params)# super().__init__ 调用父类的 __init__ 完成实例化---》HttpResponse的对象return HttpResponse(data,**kwargs)super().__init__(content=data, **kwargs)

        本质是把传入的字典或列表(必须指定safe=False),使用json序列化得到json格式字符串,最终做成HttpResponse返回给前端,如果想给json序列化的时候,传参数,必须使用json_dumps_params字典传入

cbv和fbv

# fbv:基于函数的视图,之前写的全是fbv
# cbv:基于类的视图,后续全是cbv

from django.views import View
class UserView(View):# 写方法---》跟请求方式同名的方法def get(self,request,*args,**kwargs)必须返回四件套

# 路由配置:  path('index/', 视图类名.as_view())     # as_view是类的绑定方法

源码分析:

urls.py
path('index/', index),    # 请求来了,路由匹配成功会执行 index(request,) 
path('index/', UserView.as_view()),

# 请求来了,路由匹配成功:

        1、执行 UserView.as_view()(request)
        2、as_view() 执行结果是 view,本质就是在执行 view(request)

        3、本质在执行  self.dispatch(request, *args, **kwargs)

# 方法,可以加括号调用
def view(request, *args, **kwargs):        return self.dispatch(request, *args, **kwargs)

# 去UserViwe类中找----找不到----去父类View中找dispatch,代码如下:

 def dispatch(self, request, *args, **kwargs):# request当次请求的请求对象,取出请求方式【假设是get请求】,转成小写 'get'# http_method_names = ['get', 'post', 'put']# 条件成立,执行if内部代码if request.method.lower() in self.http_method_names:#getattr:反射---》通过字符串去对象中取属性或方法# self是谁的对象? 是View这个类的对象,这个是视图类UserView的对象# 取出来的handler 是 UserView这个类的get方法handler = getattr(self, 'get')else:handler = self.http_method_not_allowed# handler是 UserView这个类的get方法# get(request)---》触发UserView这个类的get方法---》真正执行原来视图函数的内容# 最终返回return handler(request, *args, **kwargs)
"""总结:写cbv,只需要在视图类中写跟请求方式同名的方法即可--》不同请求方式,就会执行不同的方法"""

类中的self

class Animal:def run(self):# 这个self,是谁调用,就是谁print(type(self))print(self.name, '走路')
class Person(Animal):def __init__(self, name):self.name = name
class Dog(Animal):def __init__(self, name,age):self.name = nameself.age=age
# p = Person('lqz')
# p.run()  #
dog=Dog('小奶狗',6)
dog.run()

###  self 是谁调用。self就是谁,不能只看是哪个类
### 以后看到self.方法的时候,不要只从当前类,或父类中找,应该先确定当前self是谁,然后从这个对象的类根上开始找

上传文件

## 关于模板查找路径是配置文件中

setting.py/TEMPLATES
'DIRS': [os.path.join(BASE_DIR, 'templates')]

## python

class FileView(View):def get(self,request):return render(request,'file.html')def post(self,request):# 拿出文件对象my_file=request.FILES.get('myfile')print(type(my_file)) #django.core.files.uploadedfile.InMemoryUploadedFile 跟之前用的文件对象不一样但是,它应该继承了文件from django.core.files.uploadedfile import InMemoryUploadedFile# 1 保存  2 取出文件名字# my_file.save() #找了一顿,没有,所以不能使用快捷保存方式,需要自己写保存print(my_file.name) # 3-回顾django.md# 自己写保存,放在项目根路径下with open(my_file.name,'wb') as f:for line in my_file:f.write(line)return HttpResponse('上传成功')
# html
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Title</title></head>
<body>
<form action="" method="post" enctype="multipart/form-data"><input type="file" name="myfile"><br><input type="submit" value="提交">
</form>
</body>
</html>

模版层

1、介绍:

        模板在浏览器中是运行不了的,因为它有 模板语法,浏览器解析不了模板语法

        必须在后端渲染完成,变成纯粹的html,css,js

        模板语法:django template language,在后端会被渲染的类python语法

2、django模板修改的视图函数:

from django.template import Template,Context
now=datetime.datetime.now()
# 内部打开了这个模板---》读出所有内容,实例化得到了t对象
t=Template('<html><body>现在时刻是:<h1>{{current_date}}</h1></body></html>')
# #t=get_template('current_datetime.html')
c=Context({'current_date':str(now)})
html=t.render(c)
return HttpResponse(html)
#另一种写法(推荐) 
import datetime
now=datetime.datetime.now()
return render(req, 'current_datetime.html', {'current_date':str(now)[:19]})  

 # 总结:咱们之前这么写

render(request,'模板名字',context={key:value,key1:value})
本质是:t=Template('<html><body>现在时刻是:<h1>{{current_date}}</h1></body></html>')c=Context({'current_date':str(now)})html=t.render(c) # 返回是字符串HttpResponse(html)

3、页面静态化#######

def index(request):1 判断 cache文件夹下有没有 index.html  纯静态页面2 如果没有:干下面的事books = Book.object.all()t = Template('<html><body>现在时刻是:<h1>{{current_date}}</h1></body></html>')# #t=get_template('current_datetime.html')c = Context({'books':books})html = t.render(c)#保存到某个文件中  cache文件夹下 index.html 3 如果有那个文件,打开文件---》HttpReponsebooks=Book.object.all()return render(request,'index.html',{books:books})

4、模板语法###

变量:{{ 变量名 }}        #字典/列表/对象通过.拿到属性或方法

字典:dic.name--->这不是python语法    dic['name']    dic.get('name')
列表:list.2--->这不是python语法      list[0]
对象:person.name---->是python语法
person.run---->不是python语法,会自动加括号,把run的返回值放在模板中,不支持传参数
1 深度查询 用句点符
2 过滤器
3 标签:{{% % }}

5 内置过滤器####

pythohn:render(request,'index.html',{now:当前时间对象})
html:{{ now | date:"Y-m-d H:i:s" }}
safe:把标签字符串 渲染成标签
'<a href=""></a>'  

# 模板语法l是不存在xss(跨站脚本攻击)攻击的
        {{s}}   不会渲染成标签,没有xss攻击
        我们知道s是安全的,我们可以使用safe标签,把它渲染成真正的标签

6、标签for  if ...  for和if用法是重点

for:
def test(request):names=['egon','kevin']return render(request,'test.html',locals())<hr>
{% for name in names %}<p>{{ forloop.counter0 }} {{ name }}</p>
{% endfor %}
<!--
输出结果为:0 egon1 kevin
<hr>
if:
{% if num > 100 or num < 0 %}<p>无效</p>
{% elif num > 80 and num < 100 %}<p>优秀</p>
{% else %}<p>凑活吧</p>
{% endif %}

7、模板导入 include

        写好一段前端代码块,以后别的页面要用,直接 {% include 'little.html' %}

### python代码:
def index(request):return render(request, 'index.html', {'name': '彭于晏'})
little.html
<div><h1>我是广告</h1><p>亚洲最大同性交友平台</p><p>名字是:{{ name }}---诚信交友</p>
</div>
导入:
<div>{% include 'little.html' %}  
</div>

# 总结:
    -1 {{变量}}  {{变量.取值}}
    -2 {%for%}
    -3 {%if%}
    -5 内置过滤器 :data,length。。。
    -6 include
    -7 extends使用

今日思维导图:

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/182519.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Linux dig指令的十三种用法

文章目录 dig指令有哪些作用dig 具体用法推荐阅读 dig指令有哪些作用 DIG命令(Domain Information Groper命令)是一个网络工具&#xff0c;具有基本的命令行接口&#xff0c;用于进行不同的DNS(域名系统)查询。您可以使用DIG命令: 诊断您的域名服务器。检查所有这些服务器或每…

MySQL安装部署-8.0.33-脚本

#!/bin/bash set -o pipefail# 参数 # mysql_install.sh <MYSQL_PORT> <MYSQL_VERSION> <MYSQL_DATA_BASE> # sh db_install.sh 3308 5.6 /home/data # <MYSQL_DATA_BASE> &#xff1a;因为测试环境数据目录一般在 /home/data 下&#xff0c;线上在 /…

探索H5的神秘世界:测试点解析

Html5 app实际上是Web app的一种&#xff0c;在测试过程中可以延续Web App测试的部分方法&#xff0c;同时兼顾手机端的一些特性即可&#xff0c;下面帮大家总结下Html5 app 相关测试方法&#xff01; app内部H5测试点总结 1、业务逻辑 除基本功能测试外&#xff0c;需要关注的…

SpringBoot——Swagger2 接口规范

优质博文&#xff1a;IT-BLOG-CN 如今&#xff0c;REST和微服务已经有了很大的发展势头。但是&#xff0c;REST规范中并没有提供一种规范来编写我们的对外REST接口API文档。每个人都在用自己的方式记录api文档&#xff0c;因此没有一种标准规范能够让我们很容易的理解和使用该…

传感器:探索Android中的传感器功能与使用

传感器&#xff1a;探索Android中的传感器功能与使用 一、传感器介绍1.1 Android 平台三大类传感器1.2 Android 平台支持的传感器1.3 传感器框架 二、传感器的使用2.1 识别传感器和传感器特性2.2 针对不同制造商的传感器或传感器的不同版本优化2.3 监控传感器事件2.4 处理不同的…

OpenCV | 图像梯度sobel算子、scharr算子、lapkacian算子

import cv2 #opencv读取的格式是BGR import numpy as np import matplotlib.pyplot as plt#Matplotlib是RGB %matplotlib inline 1、sobel算子 img cv2.imread(pie.png,cv2.IMREAD_GRAYSCALE) cv2.imshow(img,img) cv2.waitKey() cv2.destroyAllWindows() pie图片 dst cv2.S…

vue3+vite搭建cesium项目

1.创建项目 cnpm create vite 2.安装依赖 npm i cesium vite-plugin-cesium vite -D 3.在vite.config.js里进行配置 import { defineConfig } from vite import vue from vitejs/plugin-vue import cesium from vite-plugin-cesium; export default defineConfig({plugins…

NCo3.1(08) - Nco3 服务器端编程

本篇博文不再重复ABAP调用外部服务器的基础&#xff0c;只介绍 NCo3 开发的过程和要点。需要了解相关知识点的小伙伴们自行参考&#xff1a; SAP接口编程 之JCo3.0系列(06) - Jco服务器端编程 PyRFC 服务器端编程要点 创建项目 新建一个 Console 项目&#xff0c;选择 .Net …

失落的艺术:无着色器3D渲染

假设你想创建一个甜蜜的弹跳立方体&#xff0c;如下所示&#xff1a; 一个弹跳的立方体 你可以使用 3D 框架&#xff0c;例如 OpenGL 或 Metal。 这涉及编写一个或多个顶点着色器来变换 3D 对象&#xff0c;以及编写一个或多个片段着色器来在屏幕上绘制这些变换后的对象。 然…

Python中对数组连续赋值的问题

问题描述 在python中&#xff0c;首先用两个等号对两个数组进行初始化并赋值。之后&#xff0c;对任何一个数组进行赋值&#xff0c;都会将其赋予相同值。 import numpy as np Array1 Array2 np.empty(2) Array1[0],Array2[0]70,80 print(Array1[0],Array2[0])80.0 80.0 …

旋转的数组

分享今天看到的一个题目&#xff0c;不同思路解法 题目 思路1&#xff1a;时间复杂度0(N*k&#xff09; void rotate(int *a,int N,int k)//N为数组元素个数 { while(k--) { int tema[N-1]; for(int rightN-2;right>0;right--) { a[right1]a[right]; } a[0]tem; …

聊聊VMware vSphere

VMware vSphere是一种虚拟化平台和云计算基础设施解决方案&#xff0c;由VMware公司开发。它为企业提供了一种强大的虚拟化和云计算管理平台&#xff0c;能够在数据中心中运行、管理和保护应用程序和数据。vSphere平台与VMware ESXi虚拟化操作系统相结合&#xff0c;提供了完整…

水果编曲软件FL Studio21最新中文版本2023年最新FL 21中文版如何快速入门教程

水果编曲软件FL Studio介绍 各位&#xff0c;大家晚上好&#xff0c;今天给大家带来最新最新2023水果编曲软件FL Studio 21中文版下载安装激活图文教程。我们一起先了解一些FL Studio 。FL Studio21是目前流行广泛使用人数最多音乐编曲宿主制作DAW软件&#xff0c;这款软件相信…

java开发需要用到的软件,必备软件工具一览

java开发需要用到的软件&#xff0c;必备软件工具一览 如果你对Java编程感兴趣或已经是一名Java开发者&#xff0c;你需要一些必备的软件工具来提高你的生产力和简化开发过程。在本文中&#xff0c;我们将探讨Java开发所需的关键软件工具&#xff0c;并通过具体示例来解释它们的…

最新消息:滴滴 P0 事故原因,原因出来了

最新消息滴滴P0故障原因&#xff0c;是由于k8s集群升级导致的&#xff0c;后面又进行版本回退&#xff0c;由于现在大型互联网公司基本都是基于K8s进行部署的&#xff0c;如果K8s集群一出问题&#xff0c;上面运行的业务Pod和运维系统全部都得宕机&#xff0c;导致没法回滚。 …

二叉树(判断是否为单值二叉树)

题目&#xff08;力扣&#xff09;&#xff1a; 判断二叉树上每个节点的值是否相同&#xff0c;就需要让root节点分别与左节点和右节点分别比较是否相同。 注意&#xff1a;root等于空时&#xff0c;直接可以返回true&#xff1b; 首先&#xff0c;先判断他的特殊情况&#x…

如何在安防视频监控平台EasyCVR首页增添统计设备每个小时的温度展示功能?细节如下

安防视频监控/视频集中存储/云存储/磁盘阵列EasyCVR平台可拓展性强、视频能力灵活、部署轻快&#xff0c;可支持的主流标准协议有国标GB28181、RTSP/Onvif、RTMP等&#xff0c;以及支持厂家私有协议与SDK接入&#xff0c;包括海康Ehome、海大宇等设备的SDK等。平台既具备传统安…

BLIoTLink软网关,一键解决OT层与IT层的通信

在工业自动化领域&#xff0c;协议转换一直是一个重要的问题。不同的设备、系统往往使用不同的通信协议&#xff0c;这给数据采集、设备接入等带来很大的困扰。为了解决这个问题&#xff0c;各种协议转换软件应运而生。其中&#xff0c;BLIoTLink作为一款功能强大的嵌入式工业协…

常使用的定时任务

常使用的定时任务 一、 linux自带的定时任务 1、crontab 有这样一个需求&#xff1a;我们使用Java写一个工具jar包在系统空闲的时候去采集已经部署在Linux系统上的项目的一 些数据&#xff0c;可以使用 linux 系统的 crontab。 运行crontab -e&#xff0c;可以编辑定时器&…

[密码学]DES

先声明两个基本概念 代换&#xff08;substitution&#xff09;,用别的元素代替当前元素。des的s-box遵循这一设计。 abc-->def 置换&#xff08;permutation&#xff09;&#xff0c;只改变元素的排列顺序。des的p-box遵循这一设计。 abc-->bac DES最核心的算法就是…