Django处理浏览器的请求的流程

Django处理浏览器的请求的流程

1.django处理浏览器的请求的流程步骤:

  • 请求发送到了wsgi,wsgi 封装请求的相关数据(request)
  • django去匹配路径,根据路径判断要执行哪个函数
  • 执行函数,函数中处理具体的业务逻辑
  • 函数返回响应,django按照 HTTP 协议的响应的格式进行返回

2.发请求的途径:

  • 在浏览器的地址栏中输入地址回车 —> get
  • a标签 —> get请求
  • form表单 —> post/get请求

3.get和post请求的区别

  • get 是为了 获取一个资源
  • request.GET 数据在url地址中可以看到:?k1=v1&k2=v2
  • get请求没有请求体
  • post是为了提交数据
  • request.POST
  • 数据在请求体中,不在url路径中显示

4.views.py 视图函数

def xxx(request):
    # 业务逻辑

    return  响应

# 响应的方式
HttpResponse('字符串')   # 返回一个字符串
render(request, '模板的文件名', {'k1': v1})
redirect('地址')     # 重定向

request.method    # 请求方式   GET  POST

5.ORM
models.py 模型函数

class Xxx(models.Model):
    name = models.CharField(max_length=32)   # 即类似 MySQL 数据库中的varchar(32)


class Yyy(models.Model):
    name = models.CharField(max_length=32)
    xxx = models.ForeignKey('Xxx', on_delete=models.CASCADE)
    """
    on_delete   2.0版本后是必填的
        models.CASCADE      级联删除
        models.PROTECT      保护删除
        models.SET(v)       删除后设置为某个值
        models.SETDEFAULT   删除后设为默认值
        models.SET_NULL     删除后设置为Null
        models.DO_NOTHING   什么都不做
    """

ORM的操作

from xxxx import models

models.Xxx.objects.all()   # 获取所有的数据  QuerySet 对象列表
models.Xxx.objects.get(name='xx', id='1')   # 获取一条存在且唯一的数据
models.Xxx.objects.filter(name='xx')   # 获取多条数据  

新增

models.Xxx.objects.create(name='xx')   # 新增的对象

删除

models.Xxx.objects.get(pk=1).delete()
models.Xxx.objects.filter(pk=1).delete()   # 批量删除

编辑

foo_obj.name = 'xx'
foo_obj.save()    # 保存到数据库

models.Yyy.objects.filter(pk=1).updata(name='x', xx_id=xxx的id)  # 批量更新

6.Template (部分模板语法)
return render(request, ‘模板的文件名’, {‘k1’: v1, ‘k2’: v2})


{{ k1 }}   {{ k2 }}

for 
{% for i in k1 %}
    {{ forloop.counter }}
    {{ i }}
{% endfor %}

if 
{% if 条件 %}
    xxx
{% elseif 条件1 %}
    xxx
{% else %}
    xxx
{% endif %}

...

以上就是本人的一些总结,希望对各位有所帮助。

上一篇:模型类 管理器


下一篇:30.模型中的一些查询骚操作——模型中的聚合查询,Q查询,F查询,分组查询;