Symfony-라우팅
라우팅은 요청 URI를 특정 컨트롤러의 메서드에 매핑합니다. 일반적으로 모든 URI는 다음 세 부분으로 구성됩니다.
- 호스트 이름 세그먼트
- 경로 세그먼트
- 쿼리 세그먼트
예를 들어 URI / URL에서 http://www.tutorialspoint.com/index?q=data, www.tutorialspoint.com호스트 이름 세그먼트, index는 경로 세그먼트, q = data는 쿼리 세그먼트입니다. 일반적으로 라우팅은 일련의 제약 조건에 대해 페이지 세그먼트를 확인합니다. 제약 조건이 일치하면 값 집합을 반환합니다. 주요 가치 중 하나는 컨트롤러입니다.
주석
주석은 Symfony 애플리케이션 구성에서 중요한 역할을합니다. 주석은 코딩 자체에서 구성을 선언하여 구성을 단순화합니다. 주석은 클래스, 메서드 및 속성에 대한 메타 정보를 제공하는 것입니다. 라우팅은 주석을 광범위하게 사용합니다. 주석없이 라우팅을 수행 할 수 있지만 주석은 라우팅을 크게 단순화합니다.
다음은 샘플 주석입니다.
/**
* @Route(“/student/home”)
*/
public function homeAction() {
// ...
}
라우팅 개념
“학생”프로젝트에서 생성 된 StudentController 클래스를 고려하십시오 .
StudentController.php
// src/AppBundle/Controller/StudentController.php
namespace AppBundle\Controller;
use Symfony\Bundle\FrameworkBundle\Controller\Controller;
use Sensio\Bundle\FrameworkExtraBundle\Configuration\Route;
class StudentController extends Controller {
/**
* @Route(“/student/home”)
*/
public function homeAction() {
// ...
}
/**
* @Route(“/student/about”)
*/
public function aboutAction() {
}
}
여기서 라우팅은 두 단계를 수행합니다. 당신이 가면/student/home, 첫 번째 경로가 일치하면 homeAction()실행됩니다. 그렇지 않으면/student/about, 두 번째 경로가 일치하고 aboutAction() 실행됩니다.
와일드 카드 형식 추가
페이지 2와 3에 해당하는 / student / 2 및 / student / 3와 같은 URL이있는 페이지로 매겨진 학생 기록 목록이 있다고 가정 해보십시오 . 그런 다음 경로의 경로를 변경하려는 경우 와일드 카드 형식을 사용할 수 있습니다.
예
// src/AppBundle/Controller/BlogController.php
namespace AppBundle\Controller;
use Symfony\Bundle\FrameworkBundle\Controller\Controller;
use Sensio\Bundle\FrameworkExtraBundle\Configuration\Route;
class StudentController extends Controller {
/**
* @Route(“/student/{page}", name = “student_about”, requirements = {"page": "\d+"})
*/
public function aboutAction($page) {
// ...
}
}
여기, \d+ 모든 길이의 숫자와 일치하는 정규식입니다.
자리 표시 자 지정
라우팅에서 자리 표시 자 값을 할당 할 수 있습니다. 다음과 같이 정의됩니다.
// src/AppBundle/Controller/BlogController.php
namespace AppBundle\Controller;
use Symfony\Bundle\FrameworkBundle\Controller\Controller;
use Sensio\Bundle\FrameworkExtraBundle\Configuration\Route;
class StudentController extends Controller {
/**
* @Route(“/student/{page}", name = “student_about”, requirements = {"page": "\d+"})
*/
public function aboutAction($page = 1) {
// ...
}
}
여기에서 / student로 이동하면 student_about route 일치하고 $page 기본값은 1입니다.
페이지로 리디렉션
사용자를 다른 페이지로 리디렉션하려면 redirectToRoute() 과 redirect() 행동 양식.
public function homeAction() {
// redirect to the "homepage" route
return $this->redirectToRoute('homepage');
// redirect externally
\return $this->redirect('http://example.com/doc');
}
URL 생성
URL을 생성하려면 경로 이름을 고려하십시오. student_name 및 와일드 카드 이름, student-names해당 경로의 경로에 사용됩니다. URL 생성을위한 전체 목록은 다음과 같이 정의됩니다.
class StudentController extends Controller {
public function aboutAction($name) {
// ...
// /student/student-names
$url = $this->generateUrl(
‘student_name’,
array(‘name’ =>
’student-names’)
);
}
}
StudentController
다음과 같이 StudentController 클래스의 라우팅에 대한 간단한 예제를 고려하십시오.
StudentController.php
<?php
namespace AppBundle\Controller;
use Sensio\Bundle\FrameworkExtraBundle\Configuration\Route;
use Symfony\Component\HttpFoundation\Response;
use Symfony\Bundle\FrameworkBundle\Controller\Controller;
class StudentController {
/**
* @Route("/student/home")
*/
public function homeAction() {
$name = 'Student details application';
return new Response(
'<html><body>Project: '.$name.'</body></html>'
);
}
}
이제 URL을 요청하고”http://localhost:8000/student/home” 그리고 그것은 다음과 같은 결과를 생성합니다.
마찬가지로 다른 경로를 만들 수 있습니다. aboutAction() 게다가.