Symfony2 ist ein Webentwicklungs-Framework, das auf der PHP-Sprache basiert und sich durch schnelle Entwicklungsgeschwindigkeit und hohe Leistung auszeichnet. In diesem Artikel wird die Konfiguration und Programmentwicklung des Symfony2-Frameworks anhand des Implementierungsprozesses eines Programmbeispiels ausführlich beschrieben.
Ich nehme das Ubuntu-System als Beispiel, verwende das .tgz-Komprimierungspaket, dekomprimiere die Quelldatei in das Verzeichnis /var/www und führe Folgendes aus:
tar zxvf Symfony_Standard_Vendors_2.0.###.tgz -C /var/www
The Das obige ### bezieht sich auf die Versionsnummer. Als ich es heruntergeladen habe, war es BETA5.
Nach dem Entpacken lautet das Verzeichnis von Symfony2 wie folgt:
/var/www/ <- Web根目录 Symfony/ <- Symfony2解压目录 app/ <- 存放symfony的核心文件的目录 cache/ <- 存放缓存文件的目录 config/ <- 存放应用程序全局配置的目录 logs/ <- 存放日志的目录 src/ <- 应用程序源代码 ... vendor/ <- 供应商或第三方的模组和插件 ... web/ <- Web入口 app.php <- 生产环境下的前端控制器 ...
Wenn Sie es installieren müssen (wenn Sie es ohne heruntergeladen haben). Herstellerversion) Oder wenn Sie Inhalte von Anbietern (Drittanbietern) aktualisieren, können Sie Folgendes verwenden:
cd /var/www/Symfony php bin/vendors install
2. Konfiguration
Die Konfiguration Die Installation von Symfony2 ist sehr einfach. Sie müssen lediglich Folgendes in den Browser eingeben:
http://localhost/Symfony/web/config.php
und dann den Anweisungen folgen. Bemerkenswert ist das Berechtigungsproblem der Verzeichnisse app/cache und app/logs. Da ich es unter Ubuntu installiert habe, kann ich es verwenden (Firehare ist mein Benutzername, Sie können ihn hier durch Ihren Benutzernamen ersetzen):
#为了保险起见 rm -rf app/cache/* rm -rf app/logs/* #设置ACL sudo setfacl -R -m u:www-data:rwx -m u:firehare:rwx app/cache app/logs sudo setfacl -dR -m u:www-data:rwx -m u:firehare:rwx app/cache app/logs
Wenn das System den Befehl setfacl nicht unterstützt, gibt es zwei Stellen zur Überprüfung:
Ob setfacl installiert wurde, falls nicht, können Sie dies tun Verwenden Sie die folgende Befehlsinstallation (sie scheint standardmäßig in Ubuntu 11.10 installiert zu sein, das Paket heißt acl):
sudo apt-get install setfacl
Wenn setfacl installiert wurde , überprüfen Sie bitte die Datei /etc/fstab, um zu sehen, ob die ACL-Option hinzugefügt wurde:
# /var was on /dev/sda7 during installation UUID=c2cc4104-b421-479a-b21a-1108f8895110 /var ext4 defaults,acl 0 2
Geben Sie dann den Datenbanknamen und andere Informationen entsprechend ein Sie werden auf der Seite aufgefordert, die Informationen zu kopieren. Gehen Sie wie folgt zur Datei /var/www/Symfony/app/config/parameters.ini:
; These parameters can be imported into other config files ; by enclosing the key with % (like %database_user%) ; Comments start with ';', as in php.ini [parameters] database_driver="pdo_mysql" database_host="localhost" database_name="symfony" database_user="symfony" database_password="symfony" mailer_transport="smtp" mailer_host="localhost" mailer_user="" mailer_password="" locale="zh_CN" secret="29f96e9e70c2797cb77dd088d3954d3c38d9b33f"
Wenn alles in Ordnung ist, erhalten Sie bei Eingabe der folgenden Adresse in Ihrem Browser eine Demoseite:
http://localhost/Symfony/web/app_dev.php
3. Programmieren Beispiel:
1. Bundle erstellen:
Erstellen Sie zunächst ein Bundle:
php app/console gen:bundle "AcmeHelloBundle" src 为了确保Acme名称空间可以被自动加载,请在你的app/autoload.php文件添加下列语句: $loader->registerNamespaces(array( // ... //添加自定义的名称空间 'Acme' => __DIR__.'/../src', // ... )); 最后是将该Bundle注册到Symfony2中,请在你的app/AppKernel.php文件中添加下列语句: // app/AppKernel.php public function registerBundles() { $bundles = array( // ... new AcmeHelloBundleAcmeHelloBundle(), ); // ... return $bundles; }
2. Route erstellen
Routing kann in app/config/routing.yml erstellt werden, aber um gute Programmiergewohnheiten und Codeorganisation zu haben, können Sie es in Resources/config/routing.yml im erstellten Bundle-Verzeichnis ablegen app/config/routing. Nur der Verweis auf die Routing-Datei bleibt im YML erhalten, wie unten gezeigt:
# app/config/routing.yml homepage: pattern: / defaults: { _controller: FrameworkBundle:Default:index } hello: resource: "@AcmeHelloBundle/Resources/config/routing.yml"
Die tatsächliche Route wird eingeschrieben src/Acme/HelloBundle/Resources /config/routing.yml Routing-Datei, wie folgt:
# src/Acme/HelloBundle/Resources/config/routing.yml hello: pattern: /hello/{name} defaults: { _controller: AcmeHelloBundle:Hello:index, name:'pu' }
3. Erstellen Sie einen Controller:
Controller Der Name muss HelloController.php sein, da Ihr Routing bereits den Namen des Controllers in den Zeilen 4 und 7 der Routing-Datei oben angegeben hat AcmeHelloBundle stellt den Bundle-Namen und Hello den Controller-Namen dar, daher muss der Controller HelloController.php sein und die Controller-Namenserweiterung ist die Namenskonvention. Was den nachfolgenden Index betrifft, handelt es sich beispielsweise um Methoden in der Controller-Klasse. Die Indexmethode ist unten definiert. Natürlich ist der Methodenname indexAction auch eine Namenskonvention:
// src/Acme/HelloBundle/Controller/HelloController.php namespace AcmeHelloBundleController; use SymfonyComponentHttpFoundationResponse; class HelloController { public function indexAction($name) { return new Response('<html><body>Hello '.$name.'!</body></html>'); } }
Auf diese Weise geben wir <🎜 ein > im Browser
http://localhost/hello/index/World
{# app/Resources/views/layout.html.twig #} <!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>{% block title %}Hello Application{% endblock %}</title> </head> <body> {% block body %}{% endblock %} </body> </html>
{# src/Acme/HelloBundle/Resources/views/Hello/index.html.twig #} {% extends '::layout.html.twig' %} {% block body %} Hello {{ name }}! {% endblock %}
Ändern Sie abschließend die HTML-Anweisung im Controller, um die obige Vorlage zu rendern:
// src/Acme/HelloBundle/Controller/HelloController.php namespace AcmeHelloBundleController; use SymfonyBundleFrameworkBundleControllerController; class HelloController extends Controller { public function indexAction($name) { return $this->render('AcmeHelloBundle:Hello:index.html.twig', array('name' => $name)); } }