URL 매핑

1. Django App URL 매핑

하나의 프로젝트 내에 여러 Django App이 존재한다면, 프로젝트 폴더 내의 메인 urls.py 파일 하나로 모든 URL 매핑을 하기 보다는 각각의 Django App 안에 urls.py 파일을 만들고 메인 urls.py 파일에서 각 Django App의 urls.py 파일로 URL 매핑을 위탁하게 할 수 있다. 이러한 URL 매핑 방식은 특히 다수의 App들을 포함하는 큰 프로젝트의 경우 편리한 방식이다.

아래 그림은 메인 URL 파일 (myweb/urls.py)에서 2개의 Django App URL 파일을 include 하여 사용하는 예인데, "feedback/" 으로 시작되는 URL들을 feedback.urls 즉 feedback App 안의 urls.py 에 있는 매핑을 사용하며, "home/" 로 시작되는 URL들을 home.urls 즉 home 폴더 안의 urls.py 에 있는 매핑을 사용한다.

각 Django App에 있는 urls.py는 메인과 동일한 방식으로 매핑을 정의하는데, 웹 루트(/)가 아닌 현재 App의 상대적 위치를 기준으로 URL 경로를 지정한다. 아래 두 예제는 각각 home/urls.py와 feedback/urls.py 의 내용들인데, home/urls.py 의 contact 패턴은 실제 메인에서의 home 패턴과 결합하여 "/home/contact" 를 가리킨다. 즉, /home/contact URL은 home.views.contact 함수를 호출하는 것이다. feedback 역시 "/feedback/list" 는 feedback.views.list 함수와 매핑되어 있음을 알 수 있다.

# home/urls.py
from django.conf.urls import url
from home import views

urlpatterns = [
    url(r'^contact', views.contact),
    url(r'^about', views.about),
]
# feedback/urls.py
from django.conf.urls import url
from feedback import views

urlpatterns = [
    url(r'^list', views.list),
    url(r'^add', views.add),
    url(r'^update', views.update),
]

2. URL 패턴

django.conf.urls.url() 함수의 첫번째 파라미터는 매핑 URL 패턴을 가리킨다. 이 패턴은 Regular Expression (RegEx)을 사용하며, r'정규표현식'과 같이 앞에 r (raw) Prefix를 붙인다. RegEx는 매우 다양한 기능을 가지고 있으므로, 여기서는 자주 사용되는 표현 몇 가지만 살펴 본다.

  • RegEx에서 ^은 시작을 나타내고, $은 마지막을 나타낸다. 따라서 ^$ 은 Empty string을 표현하는데, / 혹은 현재위치에 해당된다.
    url(r'^$', views.index)
    
  • URL 중 일부 문자열을 뽑아내기 (이를 Capture라 부른다) 위해서 괄호 ( )를 사용한다. 아래 예제는 4자리의 숫자와 2 자리의 숫자 두개를 Capture하는 표현이다. (모든 Capture는 문자열 이므로 결과는 실제는 숫자로 된 문자열이다) [0-9]는 0부터 9까지 숫자를 의미하며 {4}는 숫자가 네자리라는 의미이다. 만약 입력 URL이 "/blogs/2015/12" 이면, 이 URL은 views.blogs_month(request, '2015', '12') 과 같이 함수를 호출된다.
    url(r'^blogs/([0-9]{4})/([0-9]{2})/$', views.blogs_month),
    
  • 위의 예처럼 괄호를 통해 일부 문자열을 뽑아내는 것을 RegEx에서 Group이라 부르는데, Group에 이름을 붙여 사용하는 것을 Named Group이라 부른다. 즉, (?P<그룹이름>pattern) 와 같이 패턴 앞에 Group이름을 붙일 수 있다. Capture된 데이타를 파라미터로 전달할 때, 이름이 없는 Group의 경우 위치에 따라 순서대로 전달되며, Named Group의 경우는 이름과 함께 값이 전달된다. 아래와 같은 패턴의 경우 입력 URL이 "/blogs/2015/12" 이면, 이 URL은 views.blogs_month(request, year='2015', month='12') 과 같이 함수를 호출된다.
    url(r'^blogs/(?P[0-9]{4})/(?P[0-9]{2})/$', views.blogs_month),
    

정규표현식(RegEx)에 대한 자세한 내용은 RegEx 아티클을 참고하고, 패턴에 대한 보다 자세한 사항들은 URL 패턴 링크를 참조한다.

본 웹사이트는 광고를 포함하고 있습니다. 광고 클릭에서 발생하는 수익금은 모두 웹사이트 서버의 유지 및 관리, 그리고 기술 콘텐츠 향상을 위해 쓰여집니다.