>  기사  >  백엔드 개발  >  Python의 Django 프레임워크에 대한 심층적인 이해

Python의 Django 프레임워크에 대한 심층적인 이해

零到壹度
零到壹度원래의
2018-04-03 16:21:021634검색

이 글은 Django 프레임워크를 구현하기 위한 Python 코드를 주로 소개합니다. 편집자 입장에서는 꽤 좋다고 생각해서 지금 공유하고 참고용으로 올려보겠습니다. 에디터를 따라가며 함께 살펴볼까요

1. URLconf

사용자가 웹사이트를 요청하기 위해 브라우저를 통해 URL에 접속하면 해당 URL을 통해 해당 기능을 찾아 실행하게 되는데, Django의 URL은 a로 구성됩니다. 프로젝트와 동일한 이름을 가진 파일

1, 구성

(1), test1/settings.py 구성 파일

settings.py 폴더 아래 settings.py에 있는 구성은 기본적으로 ROOT_URLCONF를 통해 URL 구성을 지정했습니다. test1 .py 파일 아래의 URL에:


(2), test1/urls.py의 구성 항목은 다음과 같습니다:


참고:

test1/에서 포함 구성 수행 urls.py를 만들고 해당 애플리케이션에서 사용합니다. 해당 urls.py를 만들고 각 애플리케이션 아래의 urls.py 파일에서 특정 구성을 만듭니다.

urlpartterns 목록을 정의하고 url() 개체를 저장합니다. 이 목록의 이름은 고정되어 있습니다.

2. URL 정의

url() 객체의 구문은 django.conf.urls 패키지에 정의되어 있으며 두 가지 구문 구조

(1)로 구성됩니다. 구문 1: 동일한 이름을 가진 폴더에 URL이 포함되어 있습니다. py에는 다른 애플리케이션의 urls.py가 포함되어 있습니다

맞춤형 애플리케이션에서 urls.py 파일을 생성하여 url()을 정의한 다음, 맞춤형 urls.py를 동일한 이름의 폴더에 있는 urls.py에 삽입합니다. 이 작업의 목적은 데이터가 더 명확하고 유지 관리하기 쉽도록 애플리케이션 내부에 urls.py를 구성하는 것입니다.

test1/urls.py

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

(2)에 booktest/urls.py 구문을 도입합니다. 구문 2: 정의, URL과 뷰 함수 간의 해당 관계 지정

해당 애플리케이션 내에서 urls.py 생성, 지정 요청 주소 보기와의 해당 관계, 형식은 다음과 같습니다.

url(正则,'视图函数名称')

예:

booktest/urls.py에서 홈페이지의 URL을 생성하세요.

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

참고: 일반 환경에서는 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),

뷰의 해당 함수. py는 다음과 같이 작성됩니다:

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

(2), 키워드 매개변수

키워드 매개변수를 사용하면 url() 함수의 정규식 그룹화는 각 그룹의 이름을 지정합니다

예를 들어 액세스된 URL은 http://입니다. localhost: 8000/delete/1?a=10

url() 함수의 정규식은 다음과 같이 작성됩니다.

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

views.py의 함수는 다음과 같이 작성됩니다.

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

Note: ​​​​키워드 매개변수를 사용하는 경우 views.py에 있는 해당 함수의 매개변수 이름은 정규식의 그룹 이름과 일치해야 하며, 그렇지 않으면 오류가 보고됩니다.

2. 뷰

1. 뷰란 무엇입니까

뷰는 Python의 함수입니다. 뷰는 일반적으로 "application/views.py" 파일에 정의되어 있으며, 여기서는 "booktest/views.py"입니다. 예.

뷰는 HttpResponse 개체 또는 하위 개체를 응답으로 반환해야 합니다. 응답은 웹페이지의 HTML 콘텐츠, 리디렉션 기능 또는 404 오류 등일 수 있습니다.数 보기의 첫 번째 매개변수는 HTTPREQUEST 개체여야 합니다. 다른 매개변수에는 키워드 매개변수 또는 위치 매개변수(둘 중 하나)

2, 내장 오류 보기(1), 내장 오류 보기 맵

이 포함될 수도 있습니다.

                                                                                                                                                                         .py" 파일


(2)、404错误及视图

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

在templates中创建404.html

<html>
<head>
    <title></title>
</head>
<body>
找不到了
<hr/>
{{request_path}}
</body>
</html>

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

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 启用会话的支持时才可用,详细内容见"状态保持"。

위 내용은 Python의 Django 프레임워크에 대한 심층적인 이해의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.