Django处理浏览器的请求的流程
Posted Erudite
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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 %} ...
以上就是本人的一些总结,希望对各位有所帮助。
以上是关于Django处理浏览器的请求的流程的主要内容,如果未能解决你的问题,请参考以下文章