HttpResponse对象

  • 视图在接收请求并处理后,必须返回HttpResponse对象或子对象
  • 在django.http模块中定义了HttpResponse对象的API
  • HttpRequest对象由Django创建,HttpResponse对象由开发人员创建
  • 运行服务器,在浏览器中浏览首页,可以在浏览器“开发者工具”中看到响应信息如下图
  • 标号3为响应头信息,点击标号4处可以查看响应体信息

响应信息

属性

  • content:表示返回的内容
  • charset:表示response采用的编码字符集,默认为utf-8
  • status_code:返回的HTTP响应状态码
  • content-type:指定返回数据的的MIME类型,默认为'text/html'

方法

  • init:创建HttpResponse对象后完成返回内容的初始化
  • set_cookie:设置Cookie信息
  • write:向响应体中写数据
  • cookie是网站以键值对格式存储在浏览器中的一段纯文本信息,用于实现用户跟踪
    • max_age是一个整数,表示在指定秒数后过期
    • expires是一个datetime或timedelta对象,会话将在这个指定的日期/时间过期
    • max_age与expires二选一
    • 如果不指定过期时间,默认两个星期后过期
set_cookie(key, value='', max_age=None, expires=None)
  • delete_cookie(key):删除指定的key的Cookie,如果key不存在则什么也不发生

示例

直接返回数据

  • 打开booktest/views.py文件,定义视图index2如下
def index2(request):
    str='<h1>hello world</h1>'
    return HttpResponse(str)
  • 打开booktest/urls.py文件,配置url
    url(r'^index2/$',views.index2),
  • 运行服务器,在浏览器中打开如下网址
http://127.0.0.1:8000/index2/
  • 运行效果如下图

响应1

  • 如果使用这种方式构造一个漂亮丰富的页面,对于开发人员真是会发疯,于是就有了下面的方式

调用模板

  • 可以将html、css、js定义到一个html文件中,然后由视图来调用
  • 打开booktest/views.py文件,定义视图index3如下
from django.template import RequestContext, loader
...
def index3(request):
    #加载模板
    t1=loader.get_template('booktest/index3.html')
    #构造上下文
    context=RequestContext(request,{'h1':'hello'})
    #使用上下文渲染模板,生成字符串后返回响应对象
    return HttpResponse(t1.render(context))
  • 打开booktest/urls.py文件,配置url
    url(r'^index3/$',views.index3),
  • 在templates/booktest/目录下创建index3.html,代码如下
<html>
<head>
    <title>使用模板</title>
</head>
<body>
<h1>{{h1}}</h1>
</body>
</html>
  • 运行服务器,在浏览器中打开如下网址
http://127.0.0.1:8000/index3/
  • 运行效果如下图

响应2

调用模板简写函数render

  • 每次调用模板时都要执行加载、上下文、渲染三个步骤,为了简化操作,Django定义了render()函数封装了以上三个步骤的代码,定义在django.shortcuts模块中

  • 打开booktest/views.py文件,定义视图index3如下

from django.shortcuts import render
...
def index3(request):
    return render(request, 'booktest/index3.html', {'h1': 'hello'})
  • 是不是用render()函数调用模板比上面简单多了?