SlideShare ist ein Scribd-Unternehmen logo
1 von 13
Learning Symfony by practice
SYMFONY2
PHP Framework
About:
I part: Symfony in
theory
● Composer
● Symfony ECO system
(twig, doctrine2, assetic)
● DI or what is symfony
service container?
● Symfony configuration
● Routing
● Bundle and it's structure
● Symfony best practices
discovered using symfony
II part: Symfony in
practice. Workshop.
● DoubleBlogBundle
● What we try in practice:
– Bundle
– Controller
– Routing
– Twig
– Entities
– Forms
– Services and DI
What is SYMFONY2?
● Symfony2 is a reusable set of standalone, decoupled and
cohesive PHP components.
● Symfony2 is made from components – bundles.
● Symfony2 is also a full-stack framework.
● Compliant with PSR-0 , PSR-1, PSR-2, PSR-3.
● Very active community
● Most popular PHP project on github.com (873 contributors)
Composer
● What is composer? Dependency Manager for PHP
● composer.json http://pastebin.com/iKRtNwq8
● composer.lock
● https://packagist.org/ and http://knpbundles.com/
● When use composer update and composer install
commands?
Symfony ECO system
● Twig - the flexible, fast, and secure template engine for
PHP
● Assetic – assets + filters.
– Assets is all your application static content (css, js, images)
– Filters (LESS, SASS or CoffeeScript)
● Doctrine 2 – is library for persisting and reading
information from your database.
Twig template example
Dependency injection component
● What is DI?
– is a software design pattern that allows the removal of hard-coded
dependencies and makes it possible to change them, whether at
run-time. Dependency injection means giving an object its instance
variables. Really. That's it.
● What is Service container?
– A Service Container (or dependency injection container) is simply a
PHP object that manages the instantiation of services (i.e. objects).
● We will learn more in second part.
● http://knpuniversity.com/screencast/dependency-injection/services
Symfony configuration
● 1. Different formats for configuration: xml, yaml, ini, php,
annotations
● 2. The application in general using Yaml files.
● 3. Routing using Yaml files or annotations.
● 4. Service definitions using XML files or yaml.
● 5. Documents and entities using annotations.
● 6. Documents and entity validation using annotations.
Routing
acme_demo.article.show
        path:/articles/{culture}/{year}/{title}.{_format}
        defaults: { _controller: AcmeDemoBundle:Article:show, _format: html }
        method: GET
        requirements:
                culture: en|fr
                _format: html|rss
                year:    d+
● Earlier routes always wins
● Use YAML format.
● Routing name
– {name of the bundle without 
“Bundle”}.{name of the 
controller without “Controller”}.
{name of the action without 
“Action”}
– acme_demo.article.show
Symfony application structure
● app:/ the application configuration
● src:/ the project PHP code
● web:/ web root directory, all static content
● vendors:/ the third-party dependencies
Bundle structure
Symfony2 best practices
● Keep controller slim 
– controller code is not testable
– all business logic goes to services
● To keep it slim
– use services.
– event listeners
– Custom form handlers? 
● If you want to access global PHP variables like $_POST, $_GET, $_COOKIES values use Symfony 
Request object.
– Awoid use $request->get(‘key’). 
– use $request->query->get(‘key’) or $request->request->get(‘key’)
● When choosing ids for services, use only underscores and lowercase characters. Optionally provide 
namespacing using dots. 
● The service id for the service of class MailManager inside the MatthiasAccountBundle may be 
matthias_account.mail_manager.
● Awoid inject Symfony service container. Just in special cases.
● Awoid inject Request and Security components. Just in special cases.
Symfony workshop
● DoubleCommentBundle
● Entities: Post, PostComment
● Form: PostFormType, PostFormType
● Bundle, Controller, Routing, Twig, Services

Weitere ähnliche Inhalte

Andere mochten auch

E uam male-fin_hr
E uam male-fin_hrE uam male-fin_hr
E uam male-fin_hrHavas PR
 
Me llamo tarianna
Me llamo tariannaMe llamo tarianna
Me llamo tariannalakahaywood
 
Icai 17.02.2017 Taxation of foreign remmitances
Icai 17.02.2017 Taxation of foreign remmitancesIcai 17.02.2017 Taxation of foreign remmitances
Icai 17.02.2017 Taxation of foreign remmitancesShweta Ajmera
 
Court white paper
Court white paperCourt white paper
Court white paperHavas PR
 
The circulatory system
The circulatory systemThe circulatory system
The circulatory systemEspirituanna
 
Luis carlos martinez massa y luisa y fernanda
Luis carlos martinez massa y luisa y fernandaLuis carlos martinez massa y luisa y fernanda
Luis carlos martinez massa y luisa y fernandaLuisa Massa
 
Sound Sound - Parent info night presentation
Sound Sound - Parent info night presentationSound Sound - Parent info night presentation
Sound Sound - Parent info night presentationIsabelle Mora
 
Dse control prevention_in_dental_1_
Dse control prevention_in_dental_1_Dse control prevention_in_dental_1_
Dse control prevention_in_dental_1_Espirituanna
 
The sisterhood
The sisterhoodThe sisterhood
The sisterhoodHavas PR
 
E ukenmore fut_home_05lowres
E ukenmore fut_home_05lowresE ukenmore fut_home_05lowres
E ukenmore fut_home_05lowresHavas PR
 
데이빗라인트레이닝미팅
데이빗라인트레이닝미팅데이빗라인트레이닝미팅
데이빗라인트레이닝미팅Seung Ho Jung
 
Dental care journal
Dental care journalDental care journal
Dental care journalEspirituanna
 
E uam male-fin_lr
E uam male-fin_lrE uam male-fin_lr
E uam male-fin_lrHavas PR
 
Skeletal system lab
Skeletal system labSkeletal system lab
Skeletal system labEspirituanna
 
Court white paper
Court white paperCourt white paper
Court white paperHavas PR
 

Andere mochten auch (19)

Medellin primaveral
Medellin primaveralMedellin primaveral
Medellin primaveral
 
E uam male-fin_hr
E uam male-fin_hrE uam male-fin_hr
E uam male-fin_hr
 
Me llamo tarianna
Me llamo tariannaMe llamo tarianna
Me llamo tarianna
 
8389 work 1
8389 work 18389 work 1
8389 work 1
 
Icai 17.02.2017 Taxation of foreign remmitances
Icai 17.02.2017 Taxation of foreign remmitancesIcai 17.02.2017 Taxation of foreign remmitances
Icai 17.02.2017 Taxation of foreign remmitances
 
Court white paper
Court white paperCourt white paper
Court white paper
 
The circulatory system
The circulatory systemThe circulatory system
The circulatory system
 
Luis carlos martinez massa y luisa y fernanda
Luis carlos martinez massa y luisa y fernandaLuis carlos martinez massa y luisa y fernanda
Luis carlos martinez massa y luisa y fernanda
 
Cloud computing (1)
Cloud computing (1)Cloud computing (1)
Cloud computing (1)
 
Sound Sound - Parent info night presentation
Sound Sound - Parent info night presentationSound Sound - Parent info night presentation
Sound Sound - Parent info night presentation
 
Dse control prevention_in_dental_1_
Dse control prevention_in_dental_1_Dse control prevention_in_dental_1_
Dse control prevention_in_dental_1_
 
The sisterhood
The sisterhoodThe sisterhood
The sisterhood
 
E ukenmore fut_home_05lowres
E ukenmore fut_home_05lowresE ukenmore fut_home_05lowres
E ukenmore fut_home_05lowres
 
데이빗라인트레이닝미팅
데이빗라인트레이닝미팅데이빗라인트레이닝미팅
데이빗라인트레이닝미팅
 
Bs presentation new
Bs presentation newBs presentation new
Bs presentation new
 
Dental care journal
Dental care journalDental care journal
Dental care journal
 
E uam male-fin_lr
E uam male-fin_lrE uam male-fin_lr
E uam male-fin_lr
 
Skeletal system lab
Skeletal system labSkeletal system lab
Skeletal system lab
 
Court white paper
Court white paperCourt white paper
Court white paper
 

Ähnlich wie Learning Symfony2 by practice

An introduction to Symfony 2 for symfony 1 developers
An introduction to Symfony 2 for symfony 1 developersAn introduction to Symfony 2 for symfony 1 developers
An introduction to Symfony 2 for symfony 1 developersGiorgio Cefaro
 
PhpStorm: Symfony2 Plugin
PhpStorm: Symfony2 PluginPhpStorm: Symfony2 Plugin
PhpStorm: Symfony2 PluginHaehnchen
 
Symfony, Oxid, Composer
Symfony, Oxid, ComposerSymfony, Oxid, Composer
Symfony, Oxid, ComposerChrstn Lck
 
PHP Frameworks and Symfony
PHP Frameworks and SymfonyPHP Frameworks and Symfony
PHP Frameworks and SymfonyGlenn Guden
 
Symfony Components 2.0 on PHP 5.3
Symfony Components 2.0 on PHP 5.3Symfony Components 2.0 on PHP 5.3
Symfony Components 2.0 on PHP 5.3Fabien Potencier
 
The use of Symfony2 @ Overblog
The use of Symfony2 @ OverblogThe use of Symfony2 @ Overblog
The use of Symfony2 @ OverblogXavier Hausherr
 
IBM Connect2014 JMP106
IBM Connect2014 JMP106IBM Connect2014 JMP106
IBM Connect2014 JMP106Thomas Evans
 
How Symfony Changed My Life
How Symfony Changed My LifeHow Symfony Changed My Life
How Symfony Changed My LifeMatthias Noback
 
Symfony2 as an api
Symfony2 as an apiSymfony2 as an api
Symfony2 as an apiKifah Abbad
 
25 Intro to Symfony #burningkeyboards
25 Intro to Symfony #burningkeyboards25 Intro to Symfony #burningkeyboards
25 Intro to Symfony #burningkeyboardsDenis Ristic
 
How Symfony changed my life (#SfPot, Paris, 19th November 2015)
How Symfony changed my life (#SfPot, Paris, 19th November 2015)How Symfony changed my life (#SfPot, Paris, 19th November 2015)
How Symfony changed my life (#SfPot, Paris, 19th November 2015)Matthias Noback
 
Angular2 with type script
Angular2 with type scriptAngular2 with type script
Angular2 with type scriptRavi Mone
 
Starting with Symfony2
Starting with Symfony2Starting with Symfony2
Starting with Symfony2Kevin Bond
 
Symfony2 components to the rescue of your PHP projects
Symfony2 components to the rescue of your PHP projectsSymfony2 components to the rescue of your PHP projects
Symfony2 components to the rescue of your PHP projectsXavier Lacot
 
Symfony framework-An overview and usability for web development
Symfony framework-An overview and usability for web developmentSymfony framework-An overview and usability for web development
Symfony framework-An overview and usability for web developmentifour_bhavesh
 
Symfony 4: A new way to develop applications #ipc19
Symfony 4: A new way to develop applications #ipc19Symfony 4: A new way to develop applications #ipc19
Symfony 4: A new way to develop applications #ipc19Antonio Peric-Mazar
 
The distinct advantages of using PHP-Symfony Framework
The distinct advantages of using PHP-Symfony FrameworkThe distinct advantages of using PHP-Symfony Framework
The distinct advantages of using PHP-Symfony FrameworkMindfire LLC
 
What is new in Symfony 3,3, 3,4, 4.0, 4,1 + Flex
What is new in Symfony 3,3, 3,4, 4.0, 4,1 + FlexWhat is new in Symfony 3,3, 3,4, 4.0, 4,1 + Flex
What is new in Symfony 3,3, 3,4, 4.0, 4,1 + FlexHaehnchen
 

Ähnlich wie Learning Symfony2 by practice (20)

An introduction to Symfony 2 for symfony 1 developers
An introduction to Symfony 2 for symfony 1 developersAn introduction to Symfony 2 for symfony 1 developers
An introduction to Symfony 2 for symfony 1 developers
 
PhpStorm: Symfony2 Plugin
PhpStorm: Symfony2 PluginPhpStorm: Symfony2 Plugin
PhpStorm: Symfony2 Plugin
 
Symfony, Oxid, Composer
Symfony, Oxid, ComposerSymfony, Oxid, Composer
Symfony, Oxid, Composer
 
PHP Frameworks and Symfony
PHP Frameworks and SymfonyPHP Frameworks and Symfony
PHP Frameworks and Symfony
 
Symfony Components 2.0 on PHP 5.3
Symfony Components 2.0 on PHP 5.3Symfony Components 2.0 on PHP 5.3
Symfony Components 2.0 on PHP 5.3
 
AtoM feature development
AtoM feature developmentAtoM feature development
AtoM feature development
 
The use of Symfony2 @ Overblog
The use of Symfony2 @ OverblogThe use of Symfony2 @ Overblog
The use of Symfony2 @ Overblog
 
IBM Connect2014 JMP106
IBM Connect2014 JMP106IBM Connect2014 JMP106
IBM Connect2014 JMP106
 
How Symfony Changed My Life
How Symfony Changed My LifeHow Symfony Changed My Life
How Symfony Changed My Life
 
Symfony2 as an api
Symfony2 as an apiSymfony2 as an api
Symfony2 as an api
 
25 Intro to Symfony #burningkeyboards
25 Intro to Symfony #burningkeyboards25 Intro to Symfony #burningkeyboards
25 Intro to Symfony #burningkeyboards
 
How Symfony changed my life (#SfPot, Paris, 19th November 2015)
How Symfony changed my life (#SfPot, Paris, 19th November 2015)How Symfony changed my life (#SfPot, Paris, 19th November 2015)
How Symfony changed my life (#SfPot, Paris, 19th November 2015)
 
Angular2 with type script
Angular2 with type scriptAngular2 with type script
Angular2 with type script
 
Starting with Symfony2
Starting with Symfony2Starting with Symfony2
Starting with Symfony2
 
Symfony2 components to the rescue of your PHP projects
Symfony2 components to the rescue of your PHP projectsSymfony2 components to the rescue of your PHP projects
Symfony2 components to the rescue of your PHP projects
 
Microservices
Microservices Microservices
Microservices
 
Symfony framework-An overview and usability for web development
Symfony framework-An overview and usability for web developmentSymfony framework-An overview and usability for web development
Symfony framework-An overview and usability for web development
 
Symfony 4: A new way to develop applications #ipc19
Symfony 4: A new way to develop applications #ipc19Symfony 4: A new way to develop applications #ipc19
Symfony 4: A new way to develop applications #ipc19
 
The distinct advantages of using PHP-Symfony Framework
The distinct advantages of using PHP-Symfony FrameworkThe distinct advantages of using PHP-Symfony Framework
The distinct advantages of using PHP-Symfony Framework
 
What is new in Symfony 3,3, 3,4, 4.0, 4,1 + Flex
What is new in Symfony 3,3, 3,4, 4.0, 4,1 + FlexWhat is new in Symfony 3,3, 3,4, 4.0, 4,1 + Flex
What is new in Symfony 3,3, 3,4, 4.0, 4,1 + Flex
 

Kürzlich hochgeladen

Boost PC performance: How more available memory can improve productivity
Boost PC performance: How more available memory can improve productivityBoost PC performance: How more available memory can improve productivity
Boost PC performance: How more available memory can improve productivityPrincipled Technologies
 
Breaking the Kubernetes Kill Chain: Host Path Mount
Breaking the Kubernetes Kill Chain: Host Path MountBreaking the Kubernetes Kill Chain: Host Path Mount
Breaking the Kubernetes Kill Chain: Host Path MountPuma Security, LLC
 
Data Cloud, More than a CDP by Matt Robison
Data Cloud, More than a CDP by Matt RobisonData Cloud, More than a CDP by Matt Robison
Data Cloud, More than a CDP by Matt RobisonAnna Loughnan Colquhoun
 
Maximizing Board Effectiveness 2024 Webinar.pptx
Maximizing Board Effectiveness 2024 Webinar.pptxMaximizing Board Effectiveness 2024 Webinar.pptx
Maximizing Board Effectiveness 2024 Webinar.pptxOnBoard
 
The 7 Things I Know About Cyber Security After 25 Years | April 2024
The 7 Things I Know About Cyber Security After 25 Years | April 2024The 7 Things I Know About Cyber Security After 25 Years | April 2024
The 7 Things I Know About Cyber Security After 25 Years | April 2024Rafal Los
 
Strategies for Unlocking Knowledge Management in Microsoft 365 in the Copilot...
Strategies for Unlocking Knowledge Management in Microsoft 365 in the Copilot...Strategies for Unlocking Knowledge Management in Microsoft 365 in the Copilot...
Strategies for Unlocking Knowledge Management in Microsoft 365 in the Copilot...Drew Madelung
 
08448380779 Call Girls In Friends Colony Women Seeking Men
08448380779 Call Girls In Friends Colony Women Seeking Men08448380779 Call Girls In Friends Colony Women Seeking Men
08448380779 Call Girls In Friends Colony Women Seeking MenDelhi Call girls
 
Tech-Forward - Achieving Business Readiness For Copilot in Microsoft 365
Tech-Forward - Achieving Business Readiness For Copilot in Microsoft 365Tech-Forward - Achieving Business Readiness For Copilot in Microsoft 365
Tech-Forward - Achieving Business Readiness For Copilot in Microsoft 3652toLead Limited
 
Enhancing Worker Digital Experience: A Hands-on Workshop for Partners
Enhancing Worker Digital Experience: A Hands-on Workshop for PartnersEnhancing Worker Digital Experience: A Hands-on Workshop for Partners
Enhancing Worker Digital Experience: A Hands-on Workshop for PartnersThousandEyes
 
Scaling API-first – The story of a global engineering organization
Scaling API-first – The story of a global engineering organizationScaling API-first – The story of a global engineering organization
Scaling API-first – The story of a global engineering organizationRadu Cotescu
 
A Call to Action for Generative AI in 2024
A Call to Action for Generative AI in 2024A Call to Action for Generative AI in 2024
A Call to Action for Generative AI in 2024Results
 
Google AI Hackathon: LLM based Evaluator for RAG
Google AI Hackathon: LLM based Evaluator for RAGGoogle AI Hackathon: LLM based Evaluator for RAG
Google AI Hackathon: LLM based Evaluator for RAGSujit Pal
 
Injustice - Developers Among Us (SciFiDevCon 2024)
Injustice - Developers Among Us (SciFiDevCon 2024)Injustice - Developers Among Us (SciFiDevCon 2024)
Injustice - Developers Among Us (SciFiDevCon 2024)Allon Mureinik
 
04-2024-HHUG-Sales-and-Marketing-Alignment.pptx
04-2024-HHUG-Sales-and-Marketing-Alignment.pptx04-2024-HHUG-Sales-and-Marketing-Alignment.pptx
04-2024-HHUG-Sales-and-Marketing-Alignment.pptxHampshireHUG
 
SQL Database Design For Developers at php[tek] 2024
SQL Database Design For Developers at php[tek] 2024SQL Database Design For Developers at php[tek] 2024
SQL Database Design For Developers at php[tek] 2024Scott Keck-Warren
 
Transforming Data Streams with Kafka Connect: An Introduction to Single Messa...
Transforming Data Streams with Kafka Connect: An Introduction to Single Messa...Transforming Data Streams with Kafka Connect: An Introduction to Single Messa...
Transforming Data Streams with Kafka Connect: An Introduction to Single Messa...HostedbyConfluent
 
Automating Business Process via MuleSoft Composer | Bangalore MuleSoft Meetup...
Automating Business Process via MuleSoft Composer | Bangalore MuleSoft Meetup...Automating Business Process via MuleSoft Composer | Bangalore MuleSoft Meetup...
Automating Business Process via MuleSoft Composer | Bangalore MuleSoft Meetup...shyamraj55
 
08448380779 Call Girls In Civil Lines Women Seeking Men
08448380779 Call Girls In Civil Lines Women Seeking Men08448380779 Call Girls In Civil Lines Women Seeking Men
08448380779 Call Girls In Civil Lines Women Seeking MenDelhi Call girls
 
The Codex of Business Writing Software for Real-World Solutions 2.pptx
The Codex of Business Writing Software for Real-World Solutions 2.pptxThe Codex of Business Writing Software for Real-World Solutions 2.pptx
The Codex of Business Writing Software for Real-World Solutions 2.pptxMalak Abu Hammad
 
Histor y of HAM Radio presentation slide
Histor y of HAM Radio presentation slideHistor y of HAM Radio presentation slide
Histor y of HAM Radio presentation slidevu2urc
 

Kürzlich hochgeladen (20)

Boost PC performance: How more available memory can improve productivity
Boost PC performance: How more available memory can improve productivityBoost PC performance: How more available memory can improve productivity
Boost PC performance: How more available memory can improve productivity
 
Breaking the Kubernetes Kill Chain: Host Path Mount
Breaking the Kubernetes Kill Chain: Host Path MountBreaking the Kubernetes Kill Chain: Host Path Mount
Breaking the Kubernetes Kill Chain: Host Path Mount
 
Data Cloud, More than a CDP by Matt Robison
Data Cloud, More than a CDP by Matt RobisonData Cloud, More than a CDP by Matt Robison
Data Cloud, More than a CDP by Matt Robison
 
Maximizing Board Effectiveness 2024 Webinar.pptx
Maximizing Board Effectiveness 2024 Webinar.pptxMaximizing Board Effectiveness 2024 Webinar.pptx
Maximizing Board Effectiveness 2024 Webinar.pptx
 
The 7 Things I Know About Cyber Security After 25 Years | April 2024
The 7 Things I Know About Cyber Security After 25 Years | April 2024The 7 Things I Know About Cyber Security After 25 Years | April 2024
The 7 Things I Know About Cyber Security After 25 Years | April 2024
 
Strategies for Unlocking Knowledge Management in Microsoft 365 in the Copilot...
Strategies for Unlocking Knowledge Management in Microsoft 365 in the Copilot...Strategies for Unlocking Knowledge Management in Microsoft 365 in the Copilot...
Strategies for Unlocking Knowledge Management in Microsoft 365 in the Copilot...
 
08448380779 Call Girls In Friends Colony Women Seeking Men
08448380779 Call Girls In Friends Colony Women Seeking Men08448380779 Call Girls In Friends Colony Women Seeking Men
08448380779 Call Girls In Friends Colony Women Seeking Men
 
Tech-Forward - Achieving Business Readiness For Copilot in Microsoft 365
Tech-Forward - Achieving Business Readiness For Copilot in Microsoft 365Tech-Forward - Achieving Business Readiness For Copilot in Microsoft 365
Tech-Forward - Achieving Business Readiness For Copilot in Microsoft 365
 
Enhancing Worker Digital Experience: A Hands-on Workshop for Partners
Enhancing Worker Digital Experience: A Hands-on Workshop for PartnersEnhancing Worker Digital Experience: A Hands-on Workshop for Partners
Enhancing Worker Digital Experience: A Hands-on Workshop for Partners
 
Scaling API-first – The story of a global engineering organization
Scaling API-first – The story of a global engineering organizationScaling API-first – The story of a global engineering organization
Scaling API-first – The story of a global engineering organization
 
A Call to Action for Generative AI in 2024
A Call to Action for Generative AI in 2024A Call to Action for Generative AI in 2024
A Call to Action for Generative AI in 2024
 
Google AI Hackathon: LLM based Evaluator for RAG
Google AI Hackathon: LLM based Evaluator for RAGGoogle AI Hackathon: LLM based Evaluator for RAG
Google AI Hackathon: LLM based Evaluator for RAG
 
Injustice - Developers Among Us (SciFiDevCon 2024)
Injustice - Developers Among Us (SciFiDevCon 2024)Injustice - Developers Among Us (SciFiDevCon 2024)
Injustice - Developers Among Us (SciFiDevCon 2024)
 
04-2024-HHUG-Sales-and-Marketing-Alignment.pptx
04-2024-HHUG-Sales-and-Marketing-Alignment.pptx04-2024-HHUG-Sales-and-Marketing-Alignment.pptx
04-2024-HHUG-Sales-and-Marketing-Alignment.pptx
 
SQL Database Design For Developers at php[tek] 2024
SQL Database Design For Developers at php[tek] 2024SQL Database Design For Developers at php[tek] 2024
SQL Database Design For Developers at php[tek] 2024
 
Transforming Data Streams with Kafka Connect: An Introduction to Single Messa...
Transforming Data Streams with Kafka Connect: An Introduction to Single Messa...Transforming Data Streams with Kafka Connect: An Introduction to Single Messa...
Transforming Data Streams with Kafka Connect: An Introduction to Single Messa...
 
Automating Business Process via MuleSoft Composer | Bangalore MuleSoft Meetup...
Automating Business Process via MuleSoft Composer | Bangalore MuleSoft Meetup...Automating Business Process via MuleSoft Composer | Bangalore MuleSoft Meetup...
Automating Business Process via MuleSoft Composer | Bangalore MuleSoft Meetup...
 
08448380779 Call Girls In Civil Lines Women Seeking Men
08448380779 Call Girls In Civil Lines Women Seeking Men08448380779 Call Girls In Civil Lines Women Seeking Men
08448380779 Call Girls In Civil Lines Women Seeking Men
 
The Codex of Business Writing Software for Real-World Solutions 2.pptx
The Codex of Business Writing Software for Real-World Solutions 2.pptxThe Codex of Business Writing Software for Real-World Solutions 2.pptx
The Codex of Business Writing Software for Real-World Solutions 2.pptx
 
Histor y of HAM Radio presentation slide
Histor y of HAM Radio presentation slideHistor y of HAM Radio presentation slide
Histor y of HAM Radio presentation slide
 

Learning Symfony2 by practice