Python의 Django 프레임워크에 대한 심층적인 이해
이 글은 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'^delete(?P<id1>\d+)/$',views.show_book),
views.py의 함수는 다음과 같이 작성됩니다.
def show_arg(request,id1): return HttpResponse('show %s'%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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











PHP와 Python은 고유 한 장점과 단점이 있으며 선택은 프로젝트 요구와 개인 선호도에 달려 있습니다. 1.PHP는 대규모 웹 애플리케이션의 빠른 개발 및 유지 보수에 적합합니다. 2. Python은 데이터 과학 및 기계 학습 분야를 지배합니다.

Python과 JavaScript는 커뮤니티, 라이브러리 및 리소스 측면에서 고유 한 장점과 단점이 있습니다. 1) Python 커뮤니티는 친절하고 초보자에게 적합하지만 프론트 엔드 개발 리소스는 JavaScript만큼 풍부하지 않습니다. 2) Python은 데이터 과학 및 기계 학습 라이브러리에서 강력하며 JavaScript는 프론트 엔드 개발 라이브러리 및 프레임 워크에서 더 좋습니다. 3) 둘 다 풍부한 학습 리소스를 가지고 있지만 Python은 공식 문서로 시작하는 데 적합하지만 JavaScript는 MDNWebDocs에서 더 좋습니다. 선택은 프로젝트 요구와 개인적인 이익을 기반으로해야합니다.

Docker는 Linux 커널 기능을 사용하여 효율적이고 고립 된 응용 프로그램 실행 환경을 제공합니다. 작동 원리는 다음과 같습니다. 1. 거울은 읽기 전용 템플릿으로 사용되며, 여기에는 응용 프로그램을 실행하는 데 필요한 모든 것을 포함합니다. 2. Union 파일 시스템 (Unionfs)은 여러 파일 시스템을 스택하고 차이점 만 저장하고 공간을 절약하고 속도를 높입니다. 3. 데몬은 거울과 컨테이너를 관리하고 클라이언트는 상호 작용을 위해 사용합니다. 4. 네임 스페이스 및 CGroup은 컨테이너 격리 및 자원 제한을 구현합니다. 5. 다중 네트워크 모드는 컨테이너 상호 연결을 지원합니다. 이러한 핵심 개념을 이해 함으로써만 Docker를 더 잘 활용할 수 있습니다.

vs 코드에서는 다음 단계를 통해 터미널에서 프로그램을 실행할 수 있습니다. 코드를 준비하고 통합 터미널을 열어 코드 디렉토리가 터미널 작업 디렉토리와 일치하는지 확인하십시오. 프로그래밍 언어 (예 : Python의 Python Your_file_name.py)에 따라 실행 명령을 선택하여 성공적으로 실행되는지 여부를 확인하고 오류를 해결하십시오. 디버거를 사용하여 디버깅 효율을 향상시킵니다.

파이썬은 자동화, 스크립팅 및 작업 관리가 탁월합니다. 1) 자동화 : 파일 백업은 OS 및 Shutil과 같은 표준 라이브러리를 통해 실현됩니다. 2) 스크립트 쓰기 : PSUTIL 라이브러리를 사용하여 시스템 리소스를 모니터링합니다. 3) 작업 관리 : 일정 라이브러리를 사용하여 작업을 예약하십시오. Python의 사용 편의성과 풍부한 라이브러리 지원으로 인해 이러한 영역에서 선호하는 도구가됩니다.

VS Code는 Full Name Visual Studio Code로, Microsoft가 개발 한 무료 및 오픈 소스 크로스 플랫폼 코드 편집기 및 개발 환경입니다. 광범위한 프로그래밍 언어를 지원하고 구문 강조 표시, 코드 자동 완료, 코드 스 니펫 및 스마트 프롬프트를 제공하여 개발 효율성을 향상시킵니다. 풍부한 확장 생태계를 통해 사용자는 디버거, 코드 서식 도구 및 GIT 통합과 같은 특정 요구 및 언어에 확장을 추가 할 수 있습니다. VS 코드에는 코드에서 버그를 신속하게 찾아서 해결하는 데 도움이되는 직관적 인 디버거도 포함되어 있습니다.

VS 코드 확장은 악의적 인 코드 숨기기, 취약성 악용 및 합법적 인 확장으로 자위하는 등 악성 위험을 초래합니다. 악의적 인 확장을 식별하는 방법에는 게시자 확인, 주석 읽기, 코드 확인 및주의해서 설치가 포함됩니다. 보안 조치에는 보안 인식, 좋은 습관, 정기적 인 업데이트 및 바이러스 백신 소프트웨어도 포함됩니다.

Centos Nginx를 설치하려면 다음 단계를 수행해야합니다. 개발 도구, PCRE-DEVEL 및 OPENSSL-DEVEL과 같은 종속성 설치. nginx 소스 코드 패키지를 다운로드하고 압축을 풀고 컴파일하고 설치하고 설치 경로를/usr/local/nginx로 지정하십시오. nginx 사용자 및 사용자 그룹을 만들고 권한을 설정하십시오. 구성 파일 nginx.conf를 수정하고 청취 포트 및 도메인 이름/IP 주소를 구성하십시오. Nginx 서비스를 시작하십시오. 종속성 문제, 포트 충돌 및 구성 파일 오류와 같은 일반적인 오류는주의를 기울여야합니다. 캐시를 켜고 작업자 프로세스 수 조정과 같은 특정 상황에 따라 성능 최적화를 조정해야합니다.
