Symfony-번들

Symfony 번들은 특정 구조로 구성된 파일 및 폴더 모음입니다. 번들은 여러 애플리케이션에서 재사용 할 수있는 방식으로 모델링됩니다. 기본 애플리케이션 자체는 번들로 패키지화되며 일반적으로AppBundle.

번들은 AdminBundle (관리자 섹션), BlogBundle (사이트의 블로그) 등과 같은 응용 프로그램별로 패키지화 될 수 있습니다. 이러한 번들은 응용 프로그램간에 공유 할 수 없습니다. 대신 블로그와 같은 애플리케이션의 특정 부분을 일반 번들로 모델링하여 한 애플리케이션에서 다른 애플리케이션으로 번들을 복사하여 블로그 기능을 재사용 할 수 있습니다.

번들의 구조

번들의 기본 구조는 다음과 같습니다.

  • Controller − 모든 컨트롤러를 여기에 배치해야합니다.

  • DependencyInjection − 모든 종속성 주입 관련 코드 및 구성을 여기에 배치해야합니다.

  • Resources/config − 번들 관련 구성이 여기에 배치됩니다.

  • Resources/view − 번들 관련 뷰 템플릿이 여기에 배치됩니다.

  • Resources/public − 번들 관련 스타일 시트, 자바 스크립트, 이미지 등이 여기에 배치됩니다.

  • Tests − 번들 관련 단위 테스트 파일이 여기에 배치됩니다.

번들 생성

간단한 번들을 만들어 보겠습니다. TutorialspointDemoBundle 우리의 HelloWorld 신청.

Step 1− 네임 스페이스를 선택합니다. 번들의 네임 스페이스에는 공급 업체 이름과 번들 이름이 포함되어야합니다. 우리의 경우에는Tutorialspoint\DemoBundle.

Step 2 − 빈 클래스 생성, TutorialspointDemoBundle 연장하여 Bundle 수업하고 아래에 놓습니다. src/Tutorialspoint/DemoBundle.

namespace Tutorialspoint\DemoBundle; 
use Symfony\Component\HttpKernel\Bundle\Bundle;  

class TutorialspointDemoBundle extends Bundle { 
}

Step 3 − 응용 프로그램에서 지원하는 번들 목록에 클래스를 등록합니다. AppKernel 수업.

public function registerBundles() { 
   $bundles = array( 
      // ... 
      // register your bundle 
      new Tutorialspoint\DemoBundle\TutorialspointDemoBundle(), 
   ); 
   return $bundles; 
}

이것은 모두 빈 번들을 만드는 데 필요하며 다른 모든 개념은 응용 프로그램의 개념과 동일합니다. Symfony는 콘솔 명령도 제공합니다.generate:bundle 다음과 같이 새 번들 생성 프로세스를 단순화합니다.

php bin/console generate:bundle --namespace = Tutorialspoint/DemoBundle

결과

Welcome to the Symfony bundle generator!

Are you planning on sharing this bundle across multiple applications? [no]: no  

Your application code must be written in bundles. This command helps 
you generate them easily.  

Give your bundle a descriptive name, like BlogBundle. 
Bundle name [Tutorialspoint/DemoBundle]:   

In your code, a bundle is often referenced by its name. It can be the 
concatenation of all namespace parts but it's really up to you to come 
up with a unique name (a good practice is to start with the vendor name). 
Based on the namespace, we suggest TutorialspointDemoBundle.  

Bundle name [TutorialspointDemoBundle]:  
Bundles are usually generated into the src/ directory. Unless you're 
doing something custom, hit enter to keep this default!
Target Directory [src/]:   

What format do you want to use for your generated configuration?  

Configuration format (annotation, yml, xml, php) [annotation]:

Bundle generation

> Generating a sample bundle skeleton into app/../src/Tutorialspoint/DemoBundle 
   created ./app/../src/Tutorialspoint/DemoBundle/ 
   created ./app/../src/Tutorialspoint/DemoBundle/TutorialspointDemoBundle.php 
   created ./app/../src/Tutorialspoint/DemoBundle/Controller/ 
   created ./app/../src/Tutorialspoint/DemoBundle/Controller/DefaultController.php 
   created ./app/../tests/TutorialspointDemoBundle/Controller/   
   created ./app/../tests/TutorialspointDemoBundle/Controller/DefaultControllerTest.php 
   created ./app/../src/Tutorialspoint/DemoBundle/Resources/views/Default/   
   created ./app/../src/Tutorialspoint/DemoBundle/Resources/views/Default/index.html.twig 
   created ./app/../src/Tutorialspoint/DemoBundle/Resources/config/ 
   created ./app/../src/Tutorialspoint/DemoBundle/Resources/config/services.yml 
> Checking that the bundle is autoloaded 
> Enabling the bundle inside app/AppKernel.php 
   updated ./app/AppKernel.php 
> Importing the bundle's routes from the app/config/routing.yml file 
   updated ./app/config/routing.yml 
> Importing the bundle's services.yml from the app/config/config.yml file 
   updated ./app/config/config.yml 
Everything is OK! Now get to work :).