django入门三(视图)

it2022-05-05  86

定义视图 

本质就是一个函数视图的参数 一个HttpRequest实例通过正则表达式组获取的位置参数通过正则表达式组获得的关键字参数在应用目录下默认有views.py文件,一般视图都定义在这个文件中如果处理功能过多,可以将函数定义到不同的py文件中 1 #新建views1.py 2 #coding:utf-8 3 from django.http import HttpResponse 4 def index(request): 5 return HttpResponse("hello world") 6 7 #在urls.py中修改配置 8 from . import views1 9 url(r'^$', views1.index, name='index'),

URLCONFG  

在settings.py文件中通过ROOT_URLCONF指定根级url的配置urlpatterns是一个url()实例的列表一个url()对象包括: 正则表达式视图函数名称name编写URLconf的注意: 若要从url中捕获一个值,需要在它周围设置一对圆括号不需要添加一个前导的反斜杠,如应该写作'test/',而不应该写作'/test/'每个正则表达式前面的r表示字符串不转义请求的url被看做是一个普通的python字符串,进行匹配时不包括get或post请求的参数及域名   #只匹配“/python/1/”部分 http://www.baidu.com/python/1/?i=1&p=new  正则表达式非命名组,通过位置参数传递给视图   url(r'^([0-9]+)/$', views.detail, name='detail'), 正则表达式命名组,通过关键字参数传递给视图,本例中关键字参数为id url(r'^(?P<id>[0-9]+)/$', views.detail, name='detail'),  参数匹配规则:优先使用命名参数,如果没有命名参数则使用位置参数每个捕获的参数都作为一个普通的python字符串传递给视图性能:urlpatterns中的每个正则表达式在第一次访问它们时被编译,这使得系统相当快

包含其他的URLCONFG

在应用中创建urls.py文件,定义本应用中的urlconf,再在项目的settings中使用include() from django.conf.urls import include, url urlpatterns = [ url(r'^', include('usertest.urls', namespace='usertest')), ] 匹配过程:先与主URLconf匹配,成功后再用剩余的部分与应用中的URLconf匹配 使用include可以去除urlconf的冗余参数:视图会收到来自父URLconf、当前URLconf捕获的所有参数在include中通过namespace定义命名空间,用于反解析

URL的反向解析

如果在视图、模板中使用硬编码的链接,在urlconf发生改变时,维护是一件非常麻烦的事情解决:在做链接时,通过指向urlconf的名称,动态生成链接地址视图:使用django.core.urlresolvers.reverse()函数模板:使用url模板标签

HttpReqeust对象

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

  属性

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

HttpResponse对象

在django.http模块中定义了HttpResponse对象的APIHttpRequest对象由Django自动创建,HttpResponse对象由程序员创建不调用模板,直接返回数据

  属性

content:表示返回的内容,字符串类型charset:表示response采用的编码字符集,字符串类型status_code:响应的HTTP响应状态码content-type:指定输出的MIME类型

  方法

init :使用页内容实例化HttpResponse对象write(content):以文件的方式写flush():以文件的方式输出缓存区set_cookie(key, value='', max_age=None, expires=None):设置Cookie key、value都是字符串类型max_age是一个整数,表示在指定秒数后过期expires是一个datetime或timedelta对象,会话将在这个指定的日期/时间过期,注意datetime和timedelta值只有在使用PickleSerializer时才可序列化max_age与expires二选一如果不指定过期时间,则两个星期后过期

转载于:https://www.cnblogs.com/huashengdoujiao/p/9366229.html


最新回复(0)