Symfony - Paketler
Symfony paketi, belirli bir yapıda düzenlenmiş bir dosya ve klasörler koleksiyonudur. Paketler, birden çok uygulamada yeniden kullanılabilecek şekilde modellenmiştir. Ana uygulamanın kendisi bir paket olarak paketlenmiştir ve genellikleAppBundle.
Bir paket, AdminBundle (yönetici bölümü), BlogBundle (sitenin blogu) vb. Gibi bir uygulamaya özel olarak paketlenebilir. Bu tür paketler bir uygulama arasında paylaşılamaz. Bunun yerine, bloglar gibi uygulamanın belirli bir bölümünü genel paket olarak modelleyebiliriz, böylece blogu yeniden kullanmak için paketi bir uygulamadan başka bir uygulamaya kopyalayabiliriz.
Bir Paketin Yapısı
Bir paketin temel yapısı aşağıdaki gibidir.
Controller - Tüm denetleyicilerin buraya yerleştirilmesi gerekir.
DependencyInjection - Bağımlılık ekleme ile ilgili tüm kod ve yapılandırmanın buraya yerleştirilmesi gerekir.
Resources/config - Paketle ilgili yapılandırmalar buraya yerleştirilir.
Resources/view - Paketle ilgili görünüm şablonları buraya yerleştirilir.
Resources/public - Paketle ilgili stil sayfaları, JavaScript'ler, resimler vb. Buraya yerleştirilir.
Tests - Paketle ilgili birim test dosyaları buraya yerleştirilir.
Bir Paket Oluşturmak
Basit bir paket oluşturalım, TutorialspointDemoBundle bizim içinde HelloWorld uygulama.
Step 1- Bir ad alanı seçin. Bir paketin ad alanı, satıcı adını ve paket adını içermelidir. Bizim durumumuzdaTutorialspoint\DemoBundle.
Step 2 - Boş bir sınıf oluşturun, TutorialspointDemoBundle genişleyerek Bundle sınıf ve altına yerleştir src/Tutorialspoint/DemoBundle.
namespace Tutorialspoint\DemoBundle;
use Symfony\Component\HttpKernel\Bundle\Bundle;
class TutorialspointDemoBundle extends Bundle {
}
Step 3 - Sınıfı, uygulama tarafından desteklenen paket listesine kaydedin. AppKernel sınıf.
public function registerBundles() {
$bundles = array(
// ...
// register your bundle
new Tutorialspoint\DemoBundle\TutorialspointDemoBundle(),
);
return $bundles;
}
Bunların hepsi boş bir paket oluşturmak için gereklidir ve diğer tüm kavramlar uygulamanınkiyle aynıdır. Symfony ayrıca bir konsol komutu sağlargenerate:bundle aşağıdaki gibi yeni bir paket oluşturma sürecini basitleştirmek için.
php bin/console generate:bundle --namespace = Tutorialspoint/DemoBundle
Sonuç
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 :).