Con đường học lập trình PHP

Learn the language first, not a framework or a CMS.

Below is a basic outline of what you’ll need to know. Use this as a guide to help you find the information you need. Sorry for not posting any actual resources, but you can consider this a basic syllabus.

Basics

Like anything. Walk before you run. There is a LOT to the “basics” of any language, but these four are where you will derive most value out of PHP. Practice these things until you can do them in your sleep.

  1. The syntax (variables, arrays, if/else, loops, objects, interfaces etc)

  2. Doing stuff with $_GET and $_POST variables, and generally understanding how a request & response in PHP works.

  3. How to perform SQL queries with PDO (don’t bother learning mysql_, as it’s deprecated. Also recommend avoiding mysqli_, as its a dated procedural way to code)

  4. How to work with sessions & cookies

Security

Key security concepts to understand when building a PHP application. This is NOT a complete list, but it accounts for most of the vulnerability points an application can make. This is after the basics because it’s that important – knowing this stuff is simply not optional.

  1. Cross Site Request Forgery protection (CSRF)

  2. Filtering input to prevent malicious code execution

  3. Filtering input and using PDO prepared statements to stop SQL injection

  4. Escaping output to mitigate Cross Site Scripting vulnerabilities (XSS)

  5. How to hash and store passwords (php 5.5 made this a lot easier)

  6. How to safely upload images & files

  7. Configuring your environment for maximum error checking

Object Oriented Design

Once you’re comfortable with the basics & security, you should start thinking in terms of objects, and read up on/practice the following concepts. Like the above, do these until they’re second nature.

  1. S.O.L.I.D. principles – S is the most important.

  2. Programming to an interface

  3. Favoring composition over inheritance

  4. Dependency injection

  5. Namespaces

  6. Exceptions (not technically part of OO Design, but it’s a bit too advanced

Application Architecture

This refers to how you would structure an application from top to bottom.

  1. MVC pattern (and in general, layered architecture)

  2. Basic understanding of what is meant by a domain and Domain Driven Design (this is a big topic, but you should at least understand the basics)

  3. Using an Inversion of Control container for managing dependency injection (start with Pimple, then checkout Laravel’s IoC)

  4. Autoloading & using composer to manage external libraries and dependencies

  5. Various design patterns

  6. Unit testing

Frameworks

Knowing all of the above will help you take greater advantage of (and better appreciate) frameworks. It’s easy to do a very bad job using a good framework if you don’t quite understand the sections above. Frameworks aren’t magic bullets – they require prior knowledge to be used effectively.

There are many frameworks to choose from. The most popular full featured frameworks are Laravel and Symfony, but you should dabble in a wide variety of them to get a sense for how they solve common problems.

There are many more nooks and crannies in PHP than what I’ve outlined above, but that should be enough to get you started. The key to all of the above is practice and tinkering.

Edit: thanks for the gold kind developer!

dadkab0ns -reddit

59 points·5 years ago·edited 5 years ago

What is the best way to start learning PHP? from PHP

Leave a Reply

Your email address will not be published. Required fields are marked *