Home > Backend Development > PHP Tutorial > How to create a PHP function library and make it support dependency injection?

How to create a PHP function library and make it support dependency injection?

WBOY
Release: 2024-04-26 13:15:01
Original
472 people have browsed it

How to create a PHP function library that supports dependency injection (DI): Create a Composer package as a function library. Implement function library functions, such as implementing a greeting function in a file. Install the PhpDI container and create a container configuration, adding the function library class as a factory definition to the container. Use libraries in code and inject dependencies, such as using containers to obtain instances of library classes. In practical applications, such as saving user data to the database, injecting database connections to improve flexibility.

如何创建 PHP 函数库并使其支持依赖项注入?

How to create a PHP function library and make it support dependency injection

Introduction

Function library is a powerful tool for code reuse in PHP. By using dependency injection (DI), you can write more flexible, testable libraries. This article will show you how to create and use a DI-enabled PHP function library.

Create a function library

First, you need to create a Composer package as your function library. Using the composer package manager, create a new package by running the following command:

composer init
Copy after login

Fill in the package information and then run the following command to install the Composer autoloader:

composer install
Copy after login

Now, in your project Create a new directory to use as the library code. For example:

php
└── vendor
└── my-library
    └── src
        └── FunctionLibrary.php
Copy after login

Implement the function library

In FunctionLibrary.php, implement the function library function. For example:

namespace MyLibrary;

class FunctionLibrary
{
    public function greet(string $name): string
    {
        return "Hello, $name!";
    }
}
Copy after login

Configuring Dependency Injection

To support DI, you need to use a container to resolve dependencies. This article will use the PhpDI container.

Install PhpDI in your library package:

composer require php-di/phpdi
Copy after login

Next, create a container configuration in src/config.php:

$containerBuilder = new \DI\ContainerBuilder();
$containerBuilder->addDefinitions([
    'MyLibrary\FunctionLibrary' => \DI\factory(function () {
        return new FunctionLibrary();
    })
]);

$container = $containerBuilder->build();
Copy after login

Using function libraries

Now you can use your function library in your code and inject dependencies:

use MyLibrary\FunctionLibrary;
use DI\Container;

$container = new Container();

$functionLibrary = $container->get(FunctionLibrary::class);

echo $functionLibrary->greet('John'); // 输出:Hello, John!
Copy after login

Practical example

Suppose you have a library that saves user data to a database. You can make your library more flexible and testable by injecting the database connection in dependency injection:

namespace MyLibrary;

class UserRepository
{
    private $connection;

    public function __construct(\PDO $connection)
    {
        $this->connection = $connection;
    }

    public function persist(User $user): void
    {
        // 保存用户到数据库
    }
}
Copy after login

Then, add the following definition in the container configuration:

$containerBuilder->addDefinitions([
    \PDO::class => \DI\factory(function () {
        return new \PDO('mysql:host=localhost;dbname=my_database', 'username', 'password');
    }),
    'MyLibrary\UserRepository' => \DI\factory(function (Container $container) {
        return new UserRepository($container->get(\PDO::class));
    })
]);
Copy after login

The above is the detailed content of How to create a PHP function library and make it support dependency injection?. For more information, please follow other related articles on the PHP Chinese website!

source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template