深入了解Python之Django框架

零到壹度
Lepaskan: 2018-04-03 16:21:02
asal
1671 orang telah melayarinya

这篇文章主要介绍了Python代码实现Django框架,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

一、URLconf

        用户在通过浏览器访问网址请求网站的时候,是通过url找到对应的函数进行执行,而Django中的url配置在与项目同名的文件夹下的settings.py中进行配置

1、配置

(1)、test1/settings.py配置文件

settings.py中默认已经通过ROOT_URLCONF指定了url的配置,指向的是test1下的urls.py文件:


(2)、test1/urls.py中配置项如下:


注意:

    

        在test1/urls.py中进行包含配置,在各自应用中创建对应的urls.py,在每个应用下的urls.py文件中进行具体的配置。

        定义urlpartterns列表,存储url( )对象,这个列表名称是固定的。

2、url定义的语法

url( )对象被定义在django.conf.urls包中,由两种语法结构

(1)、语法一:包含,在项目同名文件夹下的urls.py中包含其他应用的urls.py

        在自定义的应用中创建一个urls.py文件来定义url( ),然后在项目同名文件夹下的urls.py中将自定义的urls.py引入,这样做的目的是将urls.py配置到应用内部,数据更清晰且易于维护。

test1/urls.py中引入booktest/urls.py的语法

url(r'^',include('应用名称.urls')),
# 此处的urls指的是各自应用(booktest)中urls.py文件的名称,如果是urls.py,即为urls
Salin selepas log masuk

(2)、语法二:定义,指定URL和视图函数的对应关系

在各自应用内部创建urls.py,指定请求地址与视图的对应关系,格式如下:

url(正则,'视图函数名称')
Salin selepas log masuk

示例:

booktest/urls.py中创建首页的url:

from django.conf.urls import url
from booktest import views
urlpatterns=[
    url(r'^$',views.index),
]
Salin selepas log masuk

注意:正则部分推荐使用r,表示字符串不转义,这样在正则表达式中使用\只写一个就可以。 不能在开始加反斜杠,推荐在结束加反斜杠,因为浏览器的url在结尾加\和不加都一样。

3、获取url中携带的参数值

请求的url被看作是一个普通的python字符串,进行匹配不包括域名、get或者post的请求参数,如:请求地址如下:

http://localhost:8080/detail/1?a=10

以上请求地址中,与url( )函数中正则匹配的字符串只有:detail/

如果想在请求的url中携带RESTFUL风格的参数,需要在url( )函数的正则表达式中是用分组,即使用()号,分为:位置参数、关键字参数。

注意:两种参数方式不要混合使用,在一个正则表达式中只能使用一种参数方式。

(1)、位置参数

直接使用()号,通过位置参数传递给视图

在url( )函数中的正则表达式写法为:

url(r'^detail(\d+)/$',views.show_books),
Salin selepas log masuk

views.py中对应的函数写法为:

def show_books(request, id):    # 此处获取的id为1
    return HttpResponse('show_books')
Salin selepas log masuk

(2)、关键字参数

使用关键字参数,则在url()函数中的正则表达式分组是,为每个组命名

如访问的url为:http://localhost:8000/delete/1?a=10

在url()函数的正则表达式写法为:

url(r&#39;^delete(?P<id1>\d+)/$&#39;,views.show_book),
Salin selepas log masuk

在views.py中的函数写法为:

def show_arg(request,id1):
    return HttpResponse(&#39;show %s&#39;%id1)
Salin selepas log masuk

注意:如果使用关键字参数的话,则views.py中对应的函数的参数名称必须和正则表达式中组的命名一直,否则将报错。

二、视图

1、什么是视图

视图就是python中的函数,视图一般被定义在"应用/views.py"文件中,即本例的"booktest/views.py"中。

视图必须返回一个HttpResponse对象或者子对象作为响应。响应可以是一张网页的HTML内容,也可以是一个重定向(redirect)函数,或者一个404错误等。

视图的第一个参数必须是HttpRequest对象,其他参数还可能包括:关键字参数或者位置参数(二者取其一)

2、内置错误视图

(1)、内置错误视图

Django内置处理HTTP错误的视图,主要错误及视图包括:

404:page not found 视图

500:server error 视图

如果想看到错误视图,而不是调试信息,需要修改"test/settings.py"文件中的DEBUG项配置信息


(2)、404错误及视图

将请求地址进行url匹配之后,没有找到匹配的正则表达式,则调用404视图,这个视图会调用404.html模版进行渲染,视图传递变量request_path给模版,表示导致错误的URL。

在templates中创建404.html

<html>
<head>
    <title></title>
</head>
<body>
找不到了
<hr/>
{{request_path}}
</body>
</html>
Salin selepas log masuk

在浏览器中输入如下网址:

http://localhost:8000/test/

运行效果如下:


(3)、500错误及视图

        在视图中代码运行报错将会发生500错误,调用内置错误视图,使用templates/500.html模版进行渲染。

三、HttpRequest对象

1、HttpRequest对象

        服务器接收到HTTP请求后,会根据报文创建HttpRequest对象,这个对象不需要我们手动创建,直接使用服务器构建好的对象即可。视图函数中的第一个参数必须是HttpRequest对象,该对象类定义在django.http模块中。

2、属性

        path:一个字符串,表示请求的页面的完整路径,不包含域名和参数部分。

        method:一个字符串,表示请求使用的HTTP方法,常用值包括:'GET'、'POST'。

                在浏览器中给出地址发出请求采用get方式,如超链接。

                

                在浏览器中点击表单的提交按钮发起请求,如果表单的method设置为post则为post请求。

        encoding:一个字符串,表示提交的数据的编码方式。

                如果为None则表示使用浏览器的默认设置,一般为utf-8。

                这个属性是可写的,可以通过修改它来修改访问表单数据使用的编码,接下来对属性的任何访问将使用新的encoding值。

        GET:QueryDict类型对象,类似于字典,包含get请求方式的所有参数。

        POST:QueryDict类型对象,类似于字典,包含post请求方式的所有参数。

        FILES:一个类似于字典的对象,包含所有的上传文件。

        COOKIES:一个标准的Python字典,包含所有的cookie,键和值都为字符串。

        session:一个既可读又可写的类似于字典的对象,表示当前的会话,只有当Django 启用会话的支持时才可用,详细内容见"状态保持"。

Atas ialah kandungan terperinci 深入了解Python之Django框架. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Label berkaitan:
sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan