如何在Debian10上安装和使用Composer

来自菜鸟教程
跳转至:导航、​搜索

介绍

Composer是一个流行的PHP依赖管理工具,主要是为了方便项目依赖的安装和更新。 它将检查特定项目所依赖的其他包,并根据项目要求使用适当的版本为您安装它们。 Composer 也常用于引导基于流行 PHP 框架的新项目,例如 SymfonyLaravel

在本指南中,我们将了解如何在 Debian 10 服务器上安装和使用 Composer。

先决条件

要完成本教程,您需要按照 Debian 10 初始服务器设置指南 设置一台 Debian 10 服务器,包括具有 sudo 权限的普通用户。

第 1 步 — 安装依赖项

在您下载和安装 Composer 之前,我们将确保您的服务器已安装所有依赖项。

首先,通过运行更新包管理器缓存:

sudo apt update

现在,让我们安装依赖项。 我们需要 curl 来下载 Composer 和 php-cli 来安装和运行它。 php-mbstring 包是为我们将使用的库提供函数所必需的。 Composer 使用 git 下载项目依赖项,使用 unzip 提取压缩包。 一切都可以使用以下命令安装:

sudo apt install curl php-cli php-mbstring git unzip

安装了先决条件后,我们可以安装 Composer 本身。

第 2 步 — 下载并安装 Composer

Composer 提供了一个 安装程序,用 PHP 编写。 我们将下载它,验证它没有损坏,然后使用它来安装 Composer。

确保您位于主目录中,然后使用 curl 检索安装程序:

cd ~
curl -sS https://getcomposer.org/installer -o composer-setup.php

接下来,验证安装程序是否与在 [Composer Public Keys / Signatures][composer-sigs] 页面上找到的最新安装程序的 SHA-384 哈希匹配。 从该页面复制哈希并将其存储为 shell 变量:

HASH=48e3236262b34d30969dca3c37281b3b4bbe3221bda826ac6a9a62d6444cdb0dcd0615698a5cbe587c3f0fe57a54d8f5

确保将最新的哈希值替换为突出显示的值。

现在执行以下 PHP 脚本来验证安装脚本是否可以安全运行:

php -r "if (hash_file('SHA384', 'composer-setup.php') === '$HASH') { echo 'Installer verified'; } else { echo 'Installer corrupt'; unlink('composer-setup.php'); } echo PHP_EOL;"

您将看到以下输出。

输出

Installer verified

如果您看到 Installer corrupt,那么您需要再次下载安装脚本并仔细检查您使用的哈希是否正确。 然后运行命令再次验证安装程序。 获得经过验证的安装程序后,您可以继续。

要全局安装 composer,请使用以下命令下载并安装 Composer 作为系统范围的命令,名为 composer,位于 /usr/local/bin 下:

sudo php composer-setup.php --install-dir=/usr/local/bin --filename=composer

您将看到以下输出:

OutputAll settings correct for using Composer
Downloading...

Composer (version 1.8.6) successfully installed to: /usr/local/bin/composer
Use it: php /usr/local/bin/composer

要测试您的安装,请运行:

composer

您将看到显示 Composer 的版本和参数的输出,类似于以下内容:

Output   ______
  / ____/___  ____ ___  ____  ____  ________  _____
 / /   / __ \/ __ `__ \/ __ \/ __ \/ ___/ _ \/ ___/
/ /___/ /_/ / / / / / / /_/ / /_/ (__  )  __/ /
\____/\____/_/ /_/ /_/ .___/\____/____/\___/_/
                    /_/
Composer version 1.8.6 2019-06-11 15:03:05

Usage:
  command [options] [arguments]

Options:
  -h, --help                     Display this help message
  -q, --quiet                    Do not output any message
  -V, --version                  Display this application version
      --ansi                     Force ANSI output
      --no-ansi                  Disable ANSI output
  -n, --no-interaction           Do not ask any interactive question
      --profile                  Display timing and memory usage information
      --no-plugins               Whether to disable plugins.
  -d, --working-dir=WORKING-DIR  If specified, use the given directory as working directory.
  -v|vv|vvv, --verbose           Increase the verbosity of messages: 1 for normal output, 2 for more verbose output and 3 for debug


. . .

这将验证 Composer 是否已成功安装在您的系统上并且在系统范围内可用。

注意: 如果您希望在此服务器上托管的每个项目都有单独的 Composer 可执行文件,您可以在本地安装它,基于每个项目。 NPM 的用户会熟悉这种方法。 当您的系统用户无权在系统范围内安装软件时,此方法也很有用。

为此,请使用命令 php composer-setup.php。 这会在你的当前目录下生成一个composer.phar文件,可以用./composer.phar command执行。


现在让我们看看使用 Composer 来管理 PHP 依赖项。

第 3 步 — 在 PHP 项目中使用 Composer

PHP 项目通常依赖于外部库,管理这些依赖项及其版本可能很棘手。 Composer 通过跟踪您的依赖项并让其他人轻松安装它们来解决这个问题。

为了在您的项目中使用 Composer,您需要一个 composer.json 文件。 composer.json 文件告诉 Composer 它需要为您的项目下载哪些依赖项,以及允许安装每个包的哪些版本。 这对于保持项目的一致性和避免安装可能导致向后兼容性问题的不稳定版本非常重要。

您不需要手动创建此文件 - 这样做时很容易遇到语法错误。 当您使用 require 命令向项目添加依赖项时,Composer 会自动生成 composer.json 文件。 您可以以相同的方式添加其他依赖项,而无需手动编辑此文件。

在项目中使用 Composer 安装包作为依赖项的过程包括以下步骤:

  • 确定应用程序需要什么样的库。
  • 在 Composer 的官方包存储库 Packagist.org 上研究一个合适的开源库。
  • 选择你想要依赖的包。
  • 运行 composer require 以将依赖项包含在 composer.json 文件中并安装包。

让我们用一个演示应用程序来试试这个。

此应用程序的目标是将给定的句子转换为 URL 友好的字符串 - slug。 这通常用于将页面标题转换为 URL 路径(如本教程的 URL 的最后部分)。

让我们从为我们的项目创建一个目录开始。 我们称之为 slugify

cd ~
mkdir slugify
cd slugify

现在是时候在 Packagist.org 中搜索可以帮助我们生成 slugs 的包了。 如果你在 Packagist 上搜索“slug”这个词,你会得到类似这样的结果:

您将在列表中每个包的右侧看到两个数字。 顶部的数字代表该包安装了多少次,底部的数字表示一个包在 GitHub 上被加星的次数。 您可以根据这些数字对搜索结果重新排序(查找搜索栏右侧的两个图标)。 一般来说,安装次数多、星数多的软件包往往更稳定,因为有很多人在使用它们。 检查包装说明的相关性以确保它是您需要的也很重要。

我们需要一个简单的 string-to-slug 转换器。 从搜索结果来看,包 cocur/slugify 似乎是一个很好的匹配,具有合理的安装量和星数。

Packagist 上的包有一个 vendor 名称和一个 package 名称。 每个包都有一个唯一标识符(命名空间),其格式与 GitHub 用于其存储库的格式相同,格式为 vendor/package。 我们要安装的库使用命名空间 cocur/slugif。 您需要命名空间才能在项目中使用包。

现在您确切知道要安装哪个包,运行 composer require 以将其作为依赖项包含,并为项目生成 composer.json 文件:

composer require cocur/slugify

当 Composer 下载依赖项时,您将看到以下输出:

OutputUsing version ^3.2 for cocur/slugify
./composer.json has been created
Loading composer repositories with package information
Updating dependencies (including require-dev)
Package operations: 1 install, 0 updates, 0 removals
  - Installing cocur/slugify (v3.2): Downloading (100%)         
Writing lock file
Generating autoload files

从输出中可以看出,Composer 自动决定使用哪个版本的包。 如果您现在检查项目的目录,它将包含两个新文件:composer.jsoncomposer.lock,以及一个 vendor 目录:

ls -l
Outputtotal 12
-rw-r--r-- 1 sammy sammy   59 jul 15 13:53 composer.json
-rw-r--r-- 1 sammy sammy 2952 jul 15 13:53 composer.lock
drwxr-xr-x 4 sammy sammy 4096 jul 15 13:53 vendor

composer.lock 文件用于存储有关安装每个包的哪些版本的信息,并确保在其他人克隆您的项目并安装其依赖项时使用相同的版本。 vendor 目录是项目依赖所在的位置。 vendor 文件夹不需要提交到版本控制中 - 您只需要包含 composer.jsoncomposer.lock 文件。

安装已包含 composer.json 文件的项目时,运行 composer install 以下载项目的依赖项。


让我们快速看一下版本约束。 如果您检查 composer.json 文件的内容,您会看到如下内容:

cat composer.json
Output{
    "require": {
        "cocur/slugify": "^3.2"
    }
}

您可能会注意到 composer.json 中版本号之前的特殊字符 ^。 Composer 支持多种不同的约束和格式来定义所需的包版本,以便在提供灵活性的同时保持项目的稳定性。 自动生成的 composer.json 文件使用的插入符号 (^) 运算符是推荐的运算符,以实现最大的互操作性,遵循 语义版本控制 。 在这种情况下,它将 3.2 定义为最低兼容版本,并允许更新到 4.0 以下的任何未来版本。

一般来说,您不需要篡改 composer.json 文件中的版本限制。 但是,某些情况可能需要您手动编辑约束——例如,当您需要的库的主要新版本发布并且您想要升级时,或者当您想要使用的库不遵循语义版本控制时。

以下是一些示例,可让您更好地了解 Composer 版本约束的工作原理:

约束 意义 允许的示例版本
^1.0 >= 1.0 < 2.0 1.0, 1.2.3, 1.9.9
^1.1.0 >= 1.1.0 < 2.0 1.1.0, 1.5.6, 1.9.9
~1.0 >= 1.0 < 2.0.0 1.0, 1.4.1, 1.9.9
~1.0.0 >= 1.0.0 < 1.1 1.0.0, 1.0.4, 1.0.9
1.2.1 1.2.1 1.2.1
1.* >= 1.0 < 2.0 1.0.0, 1.4.5, 1.9.9
1.2.* >= 1.2 < 1.3 1.2.0, 1.2.3, 1.2.9

更深入的 Composer 版本约束见【X62X】官方文档【X92X】。

接下来,让我们看看如何使用 Composer 自动加载依赖项。

第 4 步 — 包括自动加载脚本

由于 PHP 本身不会自动加载类,因此 Composer 提供了一个自动加载脚本,您可以将其包含在项目中以免费获得自动加载。 这使得处理依赖项变得更加容易。

您唯一需要做的就是在任何类实例化之前在您的 PHP 脚本中包含 vendor/autoload.php 文件。 当您添加第一个依赖项时,Composer 会自动生成此文件。

让我们在我们的应用程序中尝试一下。 创建文件 test.php 并在文本编辑器中打开它:

nano test.php

添加以下代码,引入 vendor/autoload.php 文件,加载 cocur/slugify 依赖项,并使用它创建一个 slug:

测试.php

<?php
require __DIR__ . '/vendor/autoload.php'; 
use Cocur\Slugify\Slugify;

$slugify = new Slugify();

echo $slugify->slugify('Hello World, this is a long sentence and I need to make a slug from it!');

保存文件并退出编辑器。

现在运行脚本:

php test.php

这将产生输出 hello-world-this-is-a-long-sentence-and-i-need-to-make-a-slug-from-it

当新版本出现时,依赖项需要更新,所以让我们看看如何处理它。

第五步——更新项目依赖

每当您想将项目依赖项更新到最新版本时,请运行 update 命令:

composer update

这将检查您项目中所需的库的较新版本。 如果找到更新的版本并且它与 composer.json 文件中定义的版本约束兼容,Composer 将替换之前安装的版本。 composer.lock 文件将更新以反映这些更改。

您还可以通过像这样指定它们来更新一个或多个特定库:

composer update vendor/package vendor2/package2

确保在更新依赖项后提交对 composer.jsoncomposer.lock 文件的更改,以便在项目中工作的任何人都可以访问相同的包版本。

结论

Composer 是每个 PHP 开发人员都应该拥有的强大工具。 在本教程中,您在 Debian 10 上安装了 Composer,并在一个简单的项目中使用了它。 您现在知道如何安装和更新依赖项。

除了提供一种简单可靠的方式来管理项目依赖项之外,它还为共享和发现社区创建的 PHP 包建立了一个新的事实标准。