django6

复习

1 web应用
	-通过浏览器访问的服务
    -cs/bs
    -基于socket
2 Http协议
	-http协议版本,0.9   1.1   2.x  3.x  有什么异同
    -请求头和响应头中的key-value
    -请求协议
    	-请求首行:请求方式,地址,协议和版本
        -请求头
        -请求体
    -响应协议
    	-响应首行:协议版本,状态码,状态
        -响应头
        -响应体:html,css,js
    -特点
    	-基于socket
        -基于请求响应
        -无状态无连接
    -url:统一资源定位符
        
3 web框架
	-wsgiref(socket的封装)自己写了一个web框架
    -(django 3.1版本后是异步框架,flask):同步框架  (tornado,sanic,fastapi):异步框架
	-其他socket服务端(遵循WSGI协议)
    	-wsgiref,uwsgi(c语言写的),tornado,gunicorn(python写的)
        -uwsgi+django
        -gunicorn+flask
4 django
	-安装(虚拟环境),创建项目,创建app
    -配路由,写视图函数,modeles
    -静态文件配置
   	-路由配置
    	-url函数,re_path函数,path函数,四个参数
        -有名,无名分组
        -路径后是否加/
        -路由分发 include
        -反向解析(通过别名拿到路径)
        -名称空间
        -2.x的转换器(5  str int )
        -自定义转化器
5 视图层
	-request对象
    	-请求方方法
        -get请求参数,地址栏中的参数
        -post请求参数,请求体中的参数(name=lqz&password=123),有的格式取不出来
        -http://127.0.0.1:8000/login/?name=lqz  向这个地址发送post请求
    -response对象
    	-三件套
8 模型层models.py
	-可以创建表,可以删除表,可以新增字段,删除字段(不能创建数据库)
	-默认使用sqlite(如果使用mysql)
	-写类,写字段
    -数据库迁移,两条命令
9 模板层
	-{{变量}}
   
10 请求生命周期,mtv和mvc
 web微信如何做的?(服务端主动向客户端推送消息)
	-轮询
    -长轮询
    -websocket:主动推送消息,应用层协议
    
    
面试题:http1.0和http1.1的区别
1.长连接
	HTTP 1.1支持长连接(PersistentConnection)和请求的流水线(Pipelining)处理,在一个TCP连接上可以传送多个HTTP请求和响应,减少了建立和关闭连接的消耗和延迟,在HTTP1.1中默认开启Connection: keep-alive,弥补了HTTP1.0每次请求都要创建连接的缺点
2.缓存处理
	在HTTP1.0中主要使用header里的If-Modified-Since,Expires来做为缓存判断的标准,HTTP1.1则引入了更多的缓存控制策略例如Entity tag,If-Unmodified-Since, If-Match, If-None-Match等更多可供选择的缓存头来控制缓存策略
3.带宽优化和网络连接的使用
	HTTP1.0中,存在一些浪费带宽的现象,例如:客户端只是需要某个对象的一部分,而服务器却将整个对象送过来了,并且不支持断点续传功能,HTTP1.1则在请求头引入了range头域,它允许只请求资源的某个部分,即返回码是206(Partial Content),方便了开发者自由的选择以便于充分利用带宽和连接
4.错误通知的管理
	在HTTP1.1中新增24个状态响应码,如409(Conflict)表示请求的资源与资源当前状态冲突;410(Gone)表示服务器上的某个资源被永久性的删除
5.Host头处理
	在HTTP1.0中认为每台服务器都绑定一个唯一的IP地址,因此,请求消息中的URL并没有传递主机名(hostname)。但随着虚拟主机技术的发展,在一台物理服务器上可以存在多个虚拟主机(Multi-homed Web Servers),并且它们共享一个IP地址。HTTP1.1的请求消息和响应消息都应支持Host头域,且请求消息中如果没有Host头域会报告一个错误(400 Bad Request)

今日内容

1 视图层之请求对象

def index(request):
    '''
    request:django封装的对象,它的类是WSGIRequest,它里面包含了所有http请求的东西
    '''
    print(request)
    print(type(request))
    # from django.core.handlers.wsgi import WSGIRequest
    #######################1 讲过的
    print(request.method)
    print(request.GET)
    print(request.POST)

    ########################2 新讲的path,get_full_path,META,FIELS,body
    # 自定制请求头
    # 上传文件使用的编码方式是form-data,默认编码方式urlencoded
    print(request.is_ajax()) # 是不是ajax请求
    print(request.path)      # 请求路径
    print(request.get_full_path()) # 请求全路径,带数据
    print(request.body)      # 请求体,二进制,如果传文件,这个报错
    '''
    使用form表单,默认情况下数据被转成name=lqz&password=123放到请求体中
    request.POST其实是从body中取出bytes格式的,转成了字典
    requet.GET其实是把路径中?后面的部分拆出来,转成了字典
    '''
    print(request.encoding) # 客户端向服务端传递时,使用的编码方法

    print(request.META)    # 重点,是字典形式,一堆东西包含请求用户的ip地址,请求头中数据,用户自定制请求头的数据等
    '''
    把请求头的key值部分统一加HTTP_  并且全部转成大写
    '''
    print(request.META['REMOTE_ADDR'])  # 客户端的ip地址
    print(request.FILES)  # 客户端上传的文件,得到是文件对象

    ########################3 暂时不用关注(后面会讲)
    print(request.COOKIES) # 空字典
    print(request.session) # session对象
    print(request.user)    # 匿名用户
    return HttpResponse('ok')

2 视图层之响应对象

### 重点:JsonResponse的使用(看源码)
需要导入 from django.http import JsonResponse
def index(request):
    # 三件套
    # return HttpResponse('ok')
    # return render(request,'index.html',context={'name':'lqz','age':18})  后面字典的值是模板层中的参数
    # return redirect('/home') # 重定向自己的地址,重定向第三方地址,经常跟反向解析一起使用

    # 向客户端返回json格式数据
    # import json
    # res=json.dumps({'name':'刘清政','age':18},ensure_ascii=False)
    # return HttpResponse(res)
    # django内置提供的JsonResponse
    # 本质还是HttpResponse

    # ensure_ascii
    # return JsonResponse({'name':'刘清政','age':18},json_dumps_params={'ensure_ascii':False})  #保证中文正常显示
    # safe,转换除字典以外的格式,需要safe=False
    return JsonResponse([11,12,13,'lqz',[1,2,3],{'name':'lqz','age':19}],safe=False)

3 cbv和fbv

# CBV基于类的视图(Class base view)和FBV基于函数的视图(Function base view)
# 之前学的全是FBV,写的是视图函数

# 写视图类(还是写在views.py中)
## 第一步,写一个类,继承View
from django.views import View

class Index(View):    # 一定要继承View
    def get(self, request):  # 当url匹配成功,get请求,会执行它
        return HttpResponse('ok')

    def post(self,request):
        return HttpResponse('post')
    
## 第二步:配置路由
path('index/', views.Index.as_view()),  执行了类调用方法as_view是父类中的方法

# 前期,全是FBV,后期,drf全是CBV
image-20201010181347889

可以继承很多种类的view,但是一般只用View,如上图,继承TemplateView时使用,后面不需要返回,内部已经封装好了,只需要template_name='html文件名'

4 文件上传

## html注意编码方式
<form action="/index/" method="post" enctype="multipart/form-data">

    <p>用户名:<input type="text" name="name"></p>
    <p>密码:<input type="password" name="password"></p>
    <p><input type="file" name="myfile"></p>
    <p><input type="submit" value="提交"></p>
</form>

# views.py
def index(request):  # 经常写成def index(request,*args,**kwargs)防止使用有名或者无名分组时出错
    file=request.FILES.get('myfile')  # 此字典的键取值是name的值,如果有多个可以用getList全部取出,get取值会默认在相同的键中取最后一个。得到的file是文件对象
    # 打开一个空文件,写入
    with open(file.name,'wb') as f:
        for line in file.chunks():   # 此处源码中用到了生成器
            f.write(line)
    return HttpResponse('文件上传成功')

6 postman软件

模拟发送http请求(控制请求路径,请求方式,请求头,请求体)

7 form表单,提交地址

# action
#1 不写,默认向当前地址发送请求
#2 /index/,向当前域(http://127.0.0.1:8000/)的/index/发送请求
#3 http://127.0.0.1:8000/index/,向该地址发送请求(可以向第三方服务发送请求)

# method
# 1 post:发送post请求(默认编码情况下:以key=value&key=value的形式拼到请求体中)
# 2 get:发送get请求(以key=value&key=value的形式拼到路径中)
<form action="/index/" method="post">

    <p>用户名:<input type="text" name="name"></p>
    <p>密码:<input type="text" name="password"></p>
    <p><input type="submit" value="提交"></p>
</form>

8 Pycharm的自动提示

from django.core.handlers.wsgi import WSGIRequest
# pycharm的自动提示,可以用到视图函数中,给予对象.后面的提示
request=request  # type: WSGIRequest
image-20201010114248189
posted @ 2020-11-12 16:06  feiguoguobokeyuan  阅读(76)  评论(0编辑  收藏  举报