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() 게다가.