Django入门-6:视图-HttpReqeust对象

简介: Django入门-6:视图-HttpReqeust对象

HttpReqeust对象

  1. 服务器接收到http协议的请求后,会根据报文创建HttpRequest对象
  2. 视图函数的第一个参数是HttpRequest对象
  3. 在django.http模块中定义了HttpRequest对象的API


属性

  1. 下面除非特别说明,属性都是只读的
  2. path:一个字符串,表示请求的页面的完整路径,不包含域名
  3. method:一个字符串,表示请求使用的HTTP方法,常用值包括:'GET''POST'
  4. encoding:一个字符串,表示提交的数据的编码方式
  1. 如果为None则表示使用浏览器的默认设置,一般为utf-8
  2. 这个属性是可写的,可以通过修改它来修改访问表单数据使用的编码,
  3. 接下来对属性的任何访问将使用新的encoding值
  1. GET:一个类似于字典的对象[QueryDict对象],包含get请求方式的所有参数
  2. POST:一个类似于字典的对象[QueryDict对象],包含post请求方式的所有参数
  3. FILES:一个类似于字典的对象[QueryDict对象],包含所有的上传文件
  4. COOKIES:一个标准的Python字典,包含所有的cookie,键和值都为字符串
  5. session:一个既可读又可写的类似于字典的对象,表示当前的会话,只有当Django 启用会话的支持时才可用,
  6. 详细内容见“Django入门-6:视图-状态保持”


方法

  1. is_ajax():如果请求是通过XMLHttpRequest发起的,则返回True


QueryDict对象

  1. 定义在django.http.QueryDict
  2. request对象的属性GET、POST都是QueryDict类型的对象
  3. 与python字典不同,QueryDict类型的对象用来处理同一个键带有多个值的情况

  1. 方法get():根据键获取值
  1. 只能获取键的一个值
  2. 如果一个键同时拥有多个值,获取最后一个值

  1. dict.get('键',default)
  2. 或简写为
  3. dict['键']


  • 方法getlist():根据键获取值
  • 将键的值以列表返回,可以获取一个键的多个值
  1. dict.getlist('键',default)


GET属性

  1. QueryDict类型的对象
  2. 包含get请求方式的所有参数
  3. 与url请求地址中的参数对应,位于?后面
  4. 参数的格式是键值对,如key1=value1
  5. 多个参数之间,使用&连接,如key1=value1&key2=value2
  6. 键是开发人员定下来的,值是可变的

  7. 示例如下
  8. 创建视图getTest1用于定义链接,getTest2用于接收一键一值,getTest3用于接收一键多值

  1. defgetTest1(request):
  2.    return render(request,'booktest/getTest1.html')
  3. defgetTest2(request):
  4.    return render(request,'booktest/getTest2.html')
  5. defgetTest3(request):
  6.    return render(request,'booktest/getTest3.html')


  • 配置url
  1. url(r'^getTest1/$', views.getTest1),
  2. url(r'^getTest2/$', views.getTest2),
  3. url(r'^getTest3/$', views.getTest3),

  • 创建getTest1.html,定义链接
  1. <html>
  2. <head>
  3.    <title>Title</title>
  4. </head>
  5. <body>
  6. 链接1:一个键传递一个值
  7. <a href="/booktest/getTest2/?a=1&b=2">gettest2</a><br>
  8. 链接2:一个键传递多个值
  9. <a href="/booktest/getTest3/?a=1&a=2&b=3">gettest3</a>
  10. </body>
  11. </html>


  • 完善视图getTest2的代码
  1. defgetTest2(request):
  2.    a=request.GET['a']
  3.    b=request.GET['b']
  4.    context={'a':a,'b':b}
  5.    return render(request,'booktest/getTest2.html',context)


  • 创建getTest2.html,显示接收结果
  1. <html>
  2. <head>
  3.    <title>Title</title>
  4. </head>
  5. <body>
  6. a:{{ a }}<br>
  7. b:{{ b }}
  8. </body>
  9. </html>


  • 完善视图getTest3的代码
  1. defgetTest3(request):
  2.    a=request.GET.getlist('a')
  3.    b=request.GET['b']
  4.    context={'a':a,'b':b}
  5.    return render(request,'booktest/getTest3.html',context)


  • 创建getTest3.html,显示接收结果
  1. <html>
  2. <head>
  3.    <title>Title</title>
  4. </head>
  5. <body>
  6. a:{% for item in a %}
  7. {{ item }}
  8. {% endfor %}
  9. <br>
  10. b:{{ b }}
  11. </body>
  12. </html>


POST属性

  1. QueryDict类型的对象
  2. 包含post请求方式的所有参数
  3. 与form表单中的控件对应
  4. 问:表单中哪些控件会被提交?
  5. 答:控件要有name属性,则name属性的值为键,value属性的值为键,构成键值对提交
  1. 对于checkbox控件,name属性一样为一组,当控件被选中后会被提交,存在一键多值的情况
  1. 键是开发人员定下来的,值是可变的
  • 示例如下
  • 定义视图postTest1
  1. defpostTest1(request):
  2.    return render(request,'booktest/postTest1.html')


  • 配置url
  1. url(r'^postTest1$',views.postTest1)


  • 创建模板postTest1.html
  1. <html>
  2. <head>
  3.    <title>Title</title>
  4. </head>
  5. <body>
  6. <form method="post" action="/booktest/postTest2/">
  7.    姓名:<inputtype="text" name="uname"/><br>
  8.    密码:<inputtype="password" name="upwd"/><br>
  9.    性别:<inputtype="radio" name="ugender" value="1"/>男
  10.    <inputtype="radio" name="ugender" value="0"/>女<br>
  11.    爱好:<inputtype="checkbox" name="uhobby" value="胸口碎大石"/>胸口碎大石
  12.    <inputtype="checkbox" name="uhobby" value="跳楼"/>跳楼
  13.    <inputtype="checkbox" name="uhobby" value="喝酒"/>喝酒
  14.    <inputtype="checkbox" name="uhobby" value="爬山"/>爬山<br>
  15.    <inputtype="submit" value="提交"/>
  16. </form>
  17. </body>
  18. </html>


  • 创建视图postTest2接收请求的数据
  1. defpostTest2(request):
  2.    uname=request.POST['uname']
  3.    upwd=request.POST['upwd']
  4.    ugender=request.POST['ugender']
  5.    uhobby=request.POST.getlist('uhobby')
  6.    context={'uname':uname,'upwd':upwd,'ugender':ugender,'uhobby':uhobby}
  7.    return render(request,'booktest/postTest2.html',context)


  • 配置url
  1. url(r'^postTest2$',views.postTest2)


  • 创建模板postTest2.html
  1. <html>
  2. <head>
  3.    <title>Title</title>
  4. </head>
  5. <body>
  6. {{ uname }}<br>
  7. {{ upwd }}<br>
  8. {{ ugender }}<br>
  9. {{ uhobby }}
  10. </body>
  11. </html>


注意:使用表单提交,注释掉settings.py中的中间件csrf


目录
相关文章
|
2月前
|
前端开发 关系型数据库 Python
Django入门到放弃之分页器
Django入门到放弃之分页器
|
22天前
|
数据处理 Python
Django视图:构建动态Web页面的核心技术
Django视图:构建动态Web页面的核心技术
|
2月前
|
C++ Python
Django视图函数VS类视图:如何选择最适合你的开发方式?
【8月更文挑战第31天】本文对比了Django中的函数视图和类视图。函数视图直接处理HTTP请求和响应,灵活且易于维护,适用于简单业务逻辑;类视图基于Python类,提供更丰富的功能和更高的灵活性,适合处理复杂业务逻辑。选择哪种视图取决于具体需求,合理使用两者可帮助你构建高效且易维护的Django应用。
16 0
|
2月前
|
关系型数据库 MySQL 机器人
Django入门到放弃之数据库配置
Django入门到放弃之数据库配置
|
2月前
|
缓存 中间件 数据库
Django入门到放弃之缓存及信号机制
Django入门到放弃之缓存及信号机制
|
2月前
|
前端开发 数据库 数据安全/隐私保护
Django入门到放弃之Auth模块
Django入门到放弃之Auth模块
|
2月前
|
JSON 前端开发 数据安全/隐私保护
Django入门到放弃之CSRF_TOKEN
Django入门到放弃之CSRF_TOKEN
|
2月前
|
前端开发 中间件 索引
Django入门到放弃之中间件
Django入门到放弃之中间件
|
2月前
|
缓存 数据库 数据安全/隐私保护
Django入门到放弃之session
Django入门到放弃之session
|
2月前
|
JavaScript 前端开发 数据安全/隐私保护
Django入门到放弃之cookies
Django入门到放弃之cookies