目录
HttpResponse介绍
常用属性
content: 返回的内容
编辑 content_type:返回给数据的MIME类型
status_code: 返回的HTTP响应状态码
render 返回网页
给网页传值
1. 指名道姓方式传值
2. 使用locals()将函数内部所有的变量名都传给网页, 包括request
redirect 重定向
传递一个具体的ORM对象(了解即可)
传递一个视图的名称
跳转至其他网址
写全地址名
JsonResponse: 返回Json格式数据
对于非字典类型的数据进行JSON序列化时, 需要修改一个safe=False参数
django服务端启动之后, 以浏览器输入不同的路径后缀, 达到访问不同的页面为例:
首先在urls.py中先做好路由与视图的关系
from django.conf.urls import url
from django.contrib import admin
from app01 import views as app01_views
urlpatterns = [
url(r'^admin/', admin.site.urls),
# 在app01 的 views.py 中写响应的函数,这里以 index 为例
url(r'^index/',app01_views.index)
]
然后浏览器会将提交上来的这些数据封装起来, 传给对应的视图函数, 视图函数在处理完相关的逻辑之后, 也需要返回一个响应给浏览器
app01.views.py文件
注意: 所有的视图函数都需要一个位置参数, 这个参数就是请求相关的所有数据对象
from django.shortcuts import render, redirect,HttpResponse
def index(request):
"""
:param request:
:return:
"""
return '响应对象'
HttpResponse介绍
常用属性
content: 返回的内容
也可以在HttpResponse()的括号内直接写
def index(request):
response = HttpResponse()
response.content='<h1>6666</h1>'
return response
或者
from django.shortcuts import render, HttpResponse, redirect
def index(request):
response = HttpResponse('<h1>6666</h1>')
return response
content_type:返回给数据的MIME类型
默认为text/html. 浏览器会根据这个属性, 来显示数据, 如果是text/html,那么就会解析这个字符串, 如果text/plain, 那么就会显示一个纯文本, 常用的content-tyoe如下;
text/html >>> 默认的HTML文件
text/plain (纯文本) 注意: 一半在使用'text/plain'时都会加上'插入色图头发', 否则会使乱码的
text/css >>> css文件
text/javascript >>>js文件
multipart/form-data >>> 文件提交
application/json >>> json传输
application/xml >>>xml文件
status_code: 返回的HTTP响应状态码
默认是200 , 也可以自己设置
常用方法
1. set_cokie: 用来设置cookie信息
2. delete_cookie: 用来删除cookie信息
3. write: HttpResponse是一个类似于文件的对象, 可以用来写入数据到数据体content中.
render 返回网页
观察源码发现, render其实也是一个HttpResponse对象, 结合一个给定的模板和一个给定的上下文字典, 并返回一个渲染后的HttpResponse对象
参数说明
request>>> 用于生成响应的请求对象
template_name >>>要使用的模板的完整名称, 可选的参数
context >>> 添加到模板上下文的一个字典, 默认是一个空字典, 如果字典中的某个值时可调用的, 视图将在模板渲染之外你调用它
content_type >>> 生成的文档要使用MIME类型, 默认为DEFALT_CONTENT_TYPE设置的值, 默认为;text/html'
status >>> 响应的状态码 默认为200
useing >>> 用于加载模板的模板引擎的名称.
template 文件夹加入配置之后, 输入网页文件的名称时, 会自动查找并提醒
from django.shortcuts import render, HttpResponse,redirect
def index(request);
response = render(request,'render_test.html')
return response
给网页传值
1. 指名道姓方式传值
render(request,'网页',{'字段1;:值,'字段2':值})
views.py 文件中
from django.shortcuts import render, HttpResponse, redirect
def index(request):
user_dict = {'name':'frank','age':18}
response = render(request,'render_test.html', {'data':user_dict,'date':123})
return response
render_test.html 通过{{ 字段 }} 拿值
<body>
<div>data:{{ data }}</div>
<div>date:{{ date }}</div>
</body>
2. 使用locals()将函数内部所有的变量名都传给网页, 包括request
from django.shortcuts import render, HttpResponse, redirect
def index(request):
user_dict = {'name':'frank','age':18}
response = render(request,'render_test.html', locals())
return response
redirect 重定向
观察源码发现. redirect 其实也是一个HttpResponse对象
参数是:
一个模型>>> 将调用模型的get_absolute_url()函数
一个视图>>> 可以带有参数, 将使用urlresolvers.reverse来反向解析名称
一个绝对的或相对的URL, 将原封不动的作为重定向的位置
默认返回一个临时的重定向, 传递permanent=True 可以返回一个永久的重定向.
例如
传递一个具体的ORM对象(了解即可)
将调用具体ORM对象的get_absoulte_url()方法来获取重定向的URL
from django.shortcuts import redirect
def my_view(request):
...
object = MyModel.objects.get(...)
return redirect(object)
传递一个视图的名称
def my_view(request):
...
return redirect('some-view-name', foo='bar')
跳转至其他网址
写全地址名
from django.shortcuts import render, HttpResponse, redirect
def index(request):
response = redirect('https://www.baidu.com/')
return response
只写后缀 , 则跳转的是该项目下的其他功能页面
urls.py
from django.conf.urls import url
from django.contrib import admin
from app01 import views as app01_views
urlpatterns = [
url(r'^admin/', admin.site.urls),
url(r'index/',app01_views.index),
url(r'home/',app01_views.home),
]
views.py
from django.shortcuts import render, HttpResponse, redirect
def index(request):
response = redirect('/home/')
return response
def home(request):
return render(request,'render_test.html')
默认情况下, redirect() 返回一个临时重定向, 以上所有的形式都接收一个parmanent参数, 如果设置为True, 将返回一个永久的重定向
def my_view(request):
...
object = MyModel.objects.get(...)
return redirect(object, permanent=True)
扩展阅读:
临时重定向(响应状态码:302)和永久重定向(响应状态码:301)对普通用户来说是没什么区别的,它主要面向的是搜索引擎的机器人。
A页面临时重定向到B页面,那搜索引擎收录的就是A页面。
A页面永久重定向到B页面,那搜索引擎收录的就是B页面。
JsonResponse: 返回Json格式数据
如果想要将json格式的数据, 通过HttpResponse返回给前端
from django.shortcuts import HttpResponse
import json
def json_data(request):
dict_data = {'username':'yietong','pwd':'123'}
# 序列化
json_data = json.dumps(dict_data)
return HttpResponse(json_data)
会发现在前端页面中, 中文的部分是被二进制数据替代了, 并没有中文展示
那么此时, 需要修改dumps方法的一个参数, ensure_ascii=False
from django.shortcuts import HttpResponse
import json
def json_data(request):
dict_data = {'username':'yieyong', 'pwd':'123'}
# 序列化
json_data = json.dumps(dict_data, ensure_ascii=False)
return HttpResponse(json_data)
而JsonResponse 其本质就是将数据自动序列化, 然后通过Httpresponse相应返回
注意: 该方法导入的模块是gjango.http
from django.http import JsonResponse
def json_data(request):
dict_data = {'username':'yietong', 'pwd':'123'}
return JsonResponse(dict_data)
会发现在前端页面中, 中文的部分是被二进制的数据替代了,并没有展示中文
观察源码发现, 其实底层原理就是调用了dumps方法, 那么只需要传入一个json_dumps_params{'ensure_ascii':False}
from django.http import JsonResponse
def json_data(request):
dict_data = {'username':'yietong', 'pwd':'123'}
return JsonResponse(dict_data, json_dumps_params{ 'ensure_ascii': False })
此时前端页面中的中文格式数据就能正常展示了
对于非字典类型的数据进行JSON序列化时, 需要修改一个safe=False参数
from django.http import JsonResponse
def json_data(request):
data = [11,22,33,44]
return JsonResponse(data, safe=False)