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

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

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

2.发请求的途径:

  1. 在浏览器的地址栏中输入地址回车 ---> get
  2. a标签 ---> get请求
  3. 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 %}

...

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

文章来源于网络,如有侵权请联系站长QQ61910465删除
本文版权归去快排wWw.seogUrublog.com 所有,如有转发请注明来出,竞价开户托管,seo优化请联系qq❉61910465