Maison >outils de développement >composer >Que fait le fichier composer.lock ?
La colonne tutorielle suivante de composer utilisant vous présentera la fonction du fichier composer.lock. J'espère qu'elle sera utile aux amis dans le besoin !
Utilisation de base de Composer
Utiliser composer.json dans le projet
Utiliser composer dans le projet, Vous devez disposer d'un fichier composer.json. Ce fichier est principalement utilisé pour déclarer les relations entre les packages et les autres balises d'éléments.
mot-clé require
La première chose à faire dans composer.json est d'utiliser le mot-clé require. Vous indiquerez au compositeur de quels packages votre projet a besoin
Le code est le suivant :{ "require": { "monolog/monolog": "1.0.*" } }Comme vous pouvez le voir, l'objet require mappera le nom du package (monolog/monolog) et la version du package est 1.0.* Le nom du package Basiquement, le nom du package est le nom principal/nom du projet (monolog/monolog). Le nom principal doit être unique, mais le nom du projet, qui est notre package, peut avoir le même nom, par exemple : igorw/json et seldaek /jsonVersion du packageLa version de monologue que nous devons utiliser est 1.0.*, ce qui signifie que tant que la version est la branche 1.0, comme 1.0.0, 1.0.2 ou 1.0.99Deux façons de définir la version : 1. Version standard : Définir un fichier de package de version garantie, tels que : 1.0.22. Une certaine plage de versions : utilisez des symboles de comparaison pour définir la plage de versions valides : >, >=, e4d9f393ac73407cb99200efa0c37a7b=1.0,8b50d3178ecf9bbcb951c78849b363051.2,c5352fb08e72ba4a82d84701b788f371=1.2.3,
Exécutez-le dans le chemin du fichier du projet
Le code est le suivant :
$ composer install
De cette façon, il téléchargera automatiquement le fichier monologue/monologue dans le répertoire de votre fournisseur.
La prochaine chose qui doit être expliquée est
composer.lock - fichier de verrouillage
Après avoir installé tous les packages requis, composer générera une version standard du package Les fichiers sont dans le fichier composer.lock. Cela verrouillera les versions de tous les packages.
Utilisez composer.lock (avec composer.json bien sûr) pour contrôler la version de votre projet
Ceci est très important lorsque nous utilisons la commande install pour le traiter, ce sera d'abord le cas. Déterminez si le fichier composer.lock existe. S'il existe, la version correspondante sera téléchargée (non basée sur la configuration dans composer.json), ce qui signifie que toute personne téléchargeant le projet obtiendra la même version.
Si composer.lock n'existe pas, composer lira le package requis et la version relative via composer.json, puis créera le fichier composer.lock
De cette façon, il pourra être utilisé dans votre Une fois que le package a une nouvelle version, vous ne serez pas automatiquement mis à jour. Pour mettre à niveau vers la nouvelle version, utilisez simplement la commande update. De cette façon, vous pourrez obtenir la dernière version du package et également mettre à jour votre fichier composer.lock.
$ php composer.phar update 或者 $ composer update
Packagist (cela devrait être composer, cela ressemble un peu à un package python, bien que pas aussi puissant, haha, avec ce standard, il sera certainement facile pour tout le monde de développer des sites Web à l'avenir, et vous peut apprendre des codes de nombreuses personnes, et c'est plus pratique ! )
Packagist est l'entrepôt principal de composer Vous pouvez le consulter. La base de composer Warehouse est le code source du package. à volonté. Packagist est conçu pour être un outil accessible à tous. Un référentiel peut être utilisé, ce qui signifie n'importe quel package requis dans votre fichier.
À propos du chargement automatiqueAfin de charger facilement les fichiers du package, Composer génère automatiquement un fichier supplier/autoload.php. Vous pouvez l'utiliser facilement n'importe où. vous devez l'utiliser
require 'vendor/autoload.php';
Cela signifie que vous pouvez utiliser du code tiers très très facilement. Si votre projet doit utiliser monlog, vous pouvez l'utiliser directement, ils ont été automatiquement chargés !
<.>Le code est le suivant :$log = new Monolog\Logger('name'); $log->pushHandler(new Monolog\Handler\StreamHandler('app.log', Monolog\Logger::WARNING)); $log->addWarning('Foo');Bien sûr, vous pouvez également charger votre propre code dans composer.json :Le code est le suivant :
{ "autoload": { "psr-0": {"Acme": "src/"} } }composer will put psr-0 Enregistré en tant qu'espace de noms Acme Vous pouvez définir un mappage vers le répertoire de fichiers via l'espace de noms. Le répertoire src est votre répertoire racine et le fournisseur est le répertoire au même niveau. : src/Acme/Foo. PHP contient la classe AcmeFoo Après avoir ajouté le chargement automatique, vous devez réinstaller pour générer le fichier supplier/autoload.php Lorsque nous référencerons ce fichier, a sera return La force de la classe autoloader, vous pouvez donc mettre la valeur renvoyée dans une variable puis ajouter plus d'espaces de noms. C'est très pratique si vous êtes dans un environnement de développement, par exemple : Le code est le suivant. :
$loader = require 'vendor/autoload.php'; $loader->add('Acme\Test', __DIR__);
Le rôle du fichier composer.lock
La commande install lit le fichier composer.json à partir du répertoire courant, traite les dépendances et l'installe dans le répertoire des fournisseurs.
Le code est le suivant :composer install
如果当前目录下存在 composer.lock 文件,它会从此文件读取依赖版本,而不是根据 composer.json 文件去获取依赖。这确保了该库的每个使用者都能得到相同的依赖版本。
如果没有 composer.lock 文件,composer 将在处理完依赖关系后创建它。
为了获取依赖的最新版本,并且升级 composer.lock 文件,你应该使用 update 命令。
代码如下:
composer update
这将解决项目的所有依赖,并将确切的版本号写入 composer.lock。
如果你只是想更新几个包,你可以像这样分别列出它们:
代码如下:
composer update vendor/package vendor/package2
你还可以使用通配符进行批量更新:
代码如下:
composer update vendor/*
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!