django视图
视图
视图的功能
视图负责接受Web请求HttpRequest,进行逻辑处理,返回Web响应HttpResponse给请求者
使用视图的过程
视图就是一个python函数,被定义在"应用/views.py"文件中。 使用视图时需要进行两方面操作,两个操作不分先后
1 在"应用/views.py"中定义视图。
def index(request):
return HttpResponse("视图函数index")
2配置URLconf,将视图函数和url对应起来。
from django.conf.urls import include, url
from django.contrib import admin
urlpatterns = [
url(r'^admin/', include(admin.site.urls)),
url(r'^', include('booktest.urls')), #这句代码是新加入的,包含booktest应用中的urls文件
]
3应用/下创建urls.py文件并编辑内容
from booktest import views #导入视图模块
urlpatterns = [
url(r'^$', views.index), #建立url和views.index视图函数的关联
]
启动服务器
127.0.0.1:8000
URLconf
用户通过在浏览器的地址栏中输入网址请求网站,对于Django开发的网站,由哪一个视图进行处理请求,是由url匹配找到的。
语法
url()对象,被定义在django.conf.urls包中,有两种语法结构:
语法一: 包含,一般在自定义应用中创建一个urls.py来定义url。
url(正则,include('应用.urls'))
1)如示例在test3/urls.py文件,包含booktest中的urls。
url(r'^',include('booktest.urls')),
- 如示例在booktest目录下创建urls.py文件。
语法二: 定义,指定URL和视图函数的对应关系
在应用内部创建urls.py文件,指定请求地址与视图的对应关系。
url(正则,'视图函数名称')
1)如示例在booktest/urls.py中创建首页的url,代码如下
from django.conf.urls import url
from booktest import views
urlpatterns=[
url(r'^$',views.index),
]
2)如示例在booktest/views.py中创建视图index
from django.shortcuts import render
from django.http import HttpResponse
def index(request):
return HttpResponse("视图函数index")
获取值
请求的url被看做是一个普通的python字符串,进行匹配时不包括域名、get或post参数。 如请求地址如下:
http://127.0.0.1:8000/delete1/?a=10
1)去除掉域名和参数部分,并将最前面的/去除后,只剩下如下部分与正则匹配。
delete1/
2)打开booktest/urls.py文件,定义与这个地址匹配的url如下:
url(r'^delete\d+/$',views.show_arg),
3)在booktest/views.py中创建视图show_arg。
def show_arg(request):
return HttpResponse('show_arg')
4)启动服务器
输入网址,浏览器会显示:
show_arg
HttpRequest对象
视图的第一个参数必须是HttpRequest对象
属性
path:一个字符串,表示请求的页面的完整路径,不包含域名和参数部分。
method:一个字符串,表示请求使用的HTTP方法,常用值包括:'GET'、'POST'。
encoding:一个字符串,表示提交的数据的编码方式。
GET:QueryDict类型对象,类似于字典,包含get请求方式的所有参数。
POST:QueryDict类型对象,类似于字典,包含post请求方式的所有参数。
FILES:一个类似于字典的对象,包含所有的上传文件。
COOKIES:一个标准的Python字典,包含所有的cookie,键和值都为字符串
session:一个既可读又可写的类似于字典的对象,表示当前的会话,只有当Django 启用会话的支持时才可用,详细内容见"状态保持"。