计算机基础知识61

news2025/1/23 21:10:31

JsonResponse 功能例子

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

1

响应头例子

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

def show(request):
# 方式一
    return JsonResponse({'fjw': 123}, headers={'xx': 'xx'})
# 方式二 # 后面headers可以同时用  也可以删掉
    res = JsonResponse
    res['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:
    @classmethod
    def 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 = name
        self.age = age
        self.gender = gender
 
    def 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 views

urlpatterns = [
    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 View

class 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 os
        basr_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格式字符串,赋值给data
   data = 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 = name
        self.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 如果有那个文件,打开文件---》HttpReponse
    books=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 egon
    1 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.coloradmin.cn/o/1268334.html

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

相关文章

软件测试项目大全,看你需要哪一个

软件测试是使用人工或者自动的手段来运行或者测定某个软件系统的过程&#xff0c;其目的在于检验它是否满足规定的需求或弄清预期结果与实际结果之间的差别。 在软件投入使用前&#xff0c;要经过一系列的严格测试&#xff0c;才能保证交付质量。 一、引言 1.编写目的 本文档…

Nat. Mach. Intell. | 预测人工智能的未来:在指数级增长的知识网络中使用基于机器学习的链接预测

今天为大家介绍的是来自Mario Krenn团队的一篇论文。一个能够通过从科学文献中获取洞见来建议新的个性化研究方向和想法的工具&#xff0c;可以加速科学的进步。一个可能受益于这种工具的领域是人工智能&#xff08;AI&#xff09;研究&#xff0c;近年来科学出版物的数量呈指数…

Kong处理web服务跨域

前言 好久没写文章了&#xff0c;大概有半年多了&#xff0c;这半年故事太多&#xff0c;本文写不下&#xff0c;就写写文章标题问题&#xff01; 问题描述 关于跨域的本质问题我这里不过多介绍&#xff0c;详细请看历史文章 跨域产生的原因以及常见的解决方案。 我这边是新…

对二分搜索的理解 Go语言版

二分搜索大家都很熟悉&#xff0c;首先我们先来看看基本框架 func binarySearch(nums []int, target int) int {left, right : 0, ...for ... {mid : left (right-left)/2if nums[mid] target {...} else if nums[mid] < target {left ...} else if nums[mid] > targ…

【Pytorch】Visualization of Feature Maps(4)——Saliency Maps

学习参考来自 Saliency Maps的原理与简单实现(使用Pytorch实现)https://github.com/wmn7/ML_Practice/tree/master/2019_07_08/Saliency%20Maps Saliency Maps 原理 《Deep Inside Convolutional Networks: Visualising Image Classification Models and Saliency Maps》&…

如何设置Linux终端提示信息

如何设置Linux终端提示信息 1 方法一&#xff1a;只能在VSCode或者Pycharm显示2 方法二&#xff1a;只能在MobaXterm等远程软件上显示&#xff0c;但全用户都会显示3 方法三&#xff1a;避免用户没看到上面的提示&#xff0c;上面两种都设置一下 在使用远程终端时&#xff0c;由…

基于Qt QChart和QChartView实现正弦、余弦、正切图表

# 源码地址 https://gitcode.com/m0_45463480/QChartView/tree/main# .pro QT += charts​​HEADERS += \ chart.h \ chartview.h​​SOURCES += \ main.cpp \ chart.cpp \ chartview.cpp​​target.path = $$[QT_INSTALL_EXAMPLES]/charts/zoomlinechartINSTAL…

L1-004:计算摄氏温度

题目描述 给定一个华氏温度F&#xff0c;本题要求编写程序&#xff0c;计算对应的摄氏温度C。计算公式&#xff1a;C5(F−32)/9。题目保证输入与输出均在整型范围内。 输入格式&#xff1a;输入在一行中给出一个华氏温度。 输出格式&#xff1a;在一行中按照格式“Celsius C”…

如何使用录屏软件在电脑录制PDF文件

我有一个PDF文件&#xff0c;想用录屏软件将它录制下来并添加上详细的注释&#xff0c;然后发给客户看&#xff0c;请问应该如何录制呢&#xff1f;有没有推荐的录屏软件呢&#xff1f; 不用担心&#xff0c;本文将会详细的为您讲解如何使用录屏软件在电脑端录制PDF文件&#…

GoLang切片

一、切片基础 1、切片的定义 切片&#xff08;Slice&#xff09;是一个拥有相同类型元素的可变长度的序列它是基于数组类型做的一层封装它非常灵活&#xff0c;支持自动扩容切片是一个引用类型&#xff0c;它的内部结构包含地址、长度和容量声明切片类型的基本语法如下&#…

Mac单独修改应用语言

方法1: 方法2: defaults write com.microsoft.Excel AppleLanguages ("zh-cn") defaults write com.microsoft.Word AppleLanguages ("zh-cn")参考&#xff1a;https://www.zhihu.com/question/24976020

Javaweb之Vue组件库Element案例的详细解析

4.4 案例 4.4.1 案例需求 参考 资料/页面原型/tlias智能学习辅助系统/首页.html 文件&#xff0c;浏览器打开&#xff0c;点击页面中的左侧栏的员工管理&#xff0c;如下所示&#xff1a; 需求说明&#xff1a; 制作类似格式的页面 即上面是标题&#xff0c;左侧栏是导航&…

vue高频面试题(2023),有回答思路,并且让你回答清晰

一、对MVC&#xff0c;MVP&#xff0c;MVVM的理解 三者都是项目的架构模式&#xff08;不是类的设计模式&#xff09;&#xff0c;即&#xff1a;一个项目的结构&#xff0c;如何分层&#xff0c;不同层负责不同的职责。 1、MVC&#xff1a; MVC的出现是用在后端&#xff08;…

SpringMVC—拦截器

1 拦截器概念 1.1 简介 拦截器是一种动态拦截方法调用的机制&#xff0c;在 SpringMVC 中动态拦截控制器方法的执行 【注】拦截器底层实现为AOP 作用&#xff1a; 在指定的方法调用前后执行预先设定的代码阻止原始方法的执行 1.2 拦截器和过滤器的区别 ① 归属不同&#…

高效的将两个文件夹中多余的文件删除

高效的将两个文件夹中多余的文件删除 解决方案 之前使用的是这个方法&#xff0c;但是图像太多&#xff0c;需要删除的有70W张&#xff0c;得删10多天。。 将两个文件夹中重复的图象删除 解决方案 先将image图像复制一份&#xff0c;然后改名为txt import osdef change_file…

SpringBoot——Swagger2 接口规范

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

【JavaWeb】会话过滤器监听器

会话&过滤器&监听器 文章目录 会话&过滤器&监听器一、会话1.1 Cookie1.2 Session1.3 三大域对象 二、过滤器三、监听器3.1 application域监听器3.2 session域监听器3.3 request域监听器3.4 session域的两个特殊监听器3.4.1 session绑定监听器3.4.2 钝化活化监听…

【Vulnhub 靶场】【Coffee Addicts: 1】【简单-中等】【20210520】

1、环境介绍 靶场介绍&#xff1a;https://www.vulnhub.com/entry/coffee-addicts-1,699/ 靶场下载&#xff1a;https://download.vulnhub.com/coffeeaddicts/coffeeaddicts.ova 靶场难度&#xff1a;简单 - 中等 发布日期&#xff1a;2021年5月20日 文件大小&#xff1a;1.3 …

SparkSQL远程调试(IDEA)

启动Intellij IDEA&#xff0c;打开spark源码项目&#xff0c;配置远程调试 Run->Edit Configuration 启动远程spark-sql spark-sql --verbose --driver-java-options "-Xdebug -Xrunjdwp:transportdt_socket,servery,suspendy,address5005"运行远程调试&#xf…

【面试】css预处理器之sass(scss)

目录 为什么引入css预处理器 可读性 嵌套&#xff1a;关系明朗 选择器 属性 伪类‘’ 变量&#xff1a;语义明确 默认变量&#xff1a;美元符号 $ 变量名:值 !default 全局变量&#xff1a;:global { $global-x: } 变量插值&#xff1a;#{} map键值对&#xff1a;$…