Points clés
composer.json
de votre projet. Cela vous permet d'utiliser tous les packages de compositeurs privés que vous créez avec Gemfury sans ajouter de référentiel séparé chaque fois que vous souhaitez utiliser le package. sudo gem install gemfury
. Supposons que vous connaissiez le compositeur, c'est le dernier et probablement le meilleur gestionnaire de packages PHP. Sinon, consultez l'introduction d'Alexander et je suis sûr que vous serez immédiatement attiré par elle. Vous devez avoir ses connaissances pratique pour tirer le meilleur parti de cet article.
Composer fonctionne de manière efficace et transparente avec Packagist, un référentiel complet de packages publics.
Cependant, tôt ou tard, vous rencontrerez un package que vous avez écrit vous-même, qui pour une raison quelconque ne peut pas être open source et partagé gratuitement via Packagist.
Il existe plusieurs options pour héberger ces forfaits privés. Vous pouvez configurer le fichier composer.json
du projet en ajoutant séparément le référentiel du package. Alternativement, SATI vous permet de générer votre propre référentiel statique. Alternativement, Toran Proxy vous permet de créer une version privée auto-hébergée de Packagist qui, une fois configuré, est plus facile à gérer que de spécifier un référentiel dans votre composer.json
.
Gemfury est une alternative au PaaS. Outre la tranquillité d'esprit (bien qu'il soit payé), les solutions hébergées sont un énorme avantage qu'il prend en charge non seulement le package PHP Composer, mais aussi Ruby Gems, Node.js NPM, Python PYPI, APT, YUM et NU -Obtenir. Ceci est très utile si vous avez plusieurs langues.
Plongeons comment l'utiliser.
Configurez votre compte
Tout d'abord, vous avez besoin d'un compte. Il y a une période d'essai de 14 jours, avec un compte gratuit limité à un collaborateur et à un forfait d'hébergement, et une gamme d'autres plans à partir de 9 $ par mois.
Vous pouvez vous inscrire à l'aide de votre adresse e-mail ou de votre compte GitHub. Allez sur le site Web pour vous inscrire.
Créez votre premier package
Pour démontrer comment utiliser Gemfury pour un package de compositeurs privé, créons un package étape par étape que nous soumettrons au service à utiliser dans d'autres projets plus tard.
La façon la plus simple de créer un nouveau package est d'utiliser la commande suivante:
composer init
Il vous pose une série de questions;
<code>... (此处省略与原文相同的composer init交互过程) ...</code>
Ensuite, ajoutons une ligne au nouveau créé
et disons-le où trouver le code source du package. composer.json
"autoload": { "psr-0": { "Acme\": "src/" } },
Dans votre répertoire de travail, créez les répertoires
et src
, puis créez le fichier suivant nommé src/Acme
: Coupon.php
<?php namespace Acme; use Faker\Factory; class Coupon { public static function generate($percent) { $faker = Factory::create(); return sprintf('%s-%s-%d', strtoupper(date('M')), strtoupper($faker->word()), intval($percent)); } }
pour charger nos seules dépendances et configurer l'autoloader. composer install
pour continuer, vous avez besoin de votre clé API. Si vous accédez à votre tableau de bord, vous le trouverez sous Paramètres.
La façon la plus simple de construire et de télécharger un package est simplement d'utiliser Git et de laisser Gemfury gérer le reste.
Créez d'abord un fichier
avec le contenu suivant: .gitignore
<code>vendor/ composer.lock</code>
git init
git add src git add composer.json
<code>https://your-username@git.fury.io/your-username/<package-name>.git</code>
par votre nom d'utilisateur Gemfury (si vous vous inscrivez avec GitHub, ce sera le même que votre nom d'utilisateur GitHub) et l'ajoutez en tant que référentiel distant: your-username
git remote add fury https://your-username@git.fury.io/your-username/coupon.git
, comme indiqué ci-dessous: composer.json
{ "name": "your-username/coupon", "description": "Generates a coupon code", "version": "1.0.0", ...
Il est important que vous utilisiez le versioning sémantique. Sinon, votre package peut ne pas être construit correctement;ou, vous pouvez utiliser la balise git. Par exemple, créez une nouvelle version avec une balise, comme illustré ci-dessous:
git tag -a 1.0.0 -m "Version 1.0.0"
git commit -a -m "Initial commit"
git push fury master --tags
Maintenant, si vous accédez à votre tableau de bord, vous devriez voir que votre nouveau référentiel est répertorié. Ensuite, voyons comment vous l'utilisez dans votre projet.
Utilisation du package privé
Si vous revenez au tableau de bord et sélectionnez "Reposs" à gauche, vous trouverez votre URL de référentiel privé. Cela doit être maintenu privé, alors assurez-vous de le protéger. Cela ressemblera à ceci:
<code>https://php.fury.io/SECRET-CODE/your-username/</code>
qui le rend imprévisible et est donc en fait privé. SECRET-CODE
: composer.json
de votre projet
composer init
Il vous suffit d'ajouter ce référentiel pour utiliser tous les packages de compositeurs privés que vous avez créés avec Gemfury. Il n'est pas nécessaire d'ajouter un référentiel séparé chaque fois que vous souhaitez utiliser le package.
Maintenant, vous pouvez avoir besoin de votre forfait privé comme vous le faites sur Packagist. Voici un exemple complet d'un projet composer.json
:
<code>... (此处省略与原文相同的composer init交互过程) ...</code>
Autres méthodes
Personnellement, je crois que l'utilisation de Git et des balises est le moyen le plus simple et le plus efficace de gérer les packages.
ou, si vous préférez, vous pouvez le construire vous-même en zippant le code source du package et en le téléchargeant sur le tableau de bord Gemfury.
outil de ligne de commande
Gemfury fournit également un outil de ligne de commande. Pour l'installer:
"autoload": { "psr-0": { "Acme\": "src/" } },
Pour répertorier votre package, vous pouvez utiliser la commande suivante:
<?php namespace Acme; use Faker\Factory; class Coupon { public static function generate($percent) { $faker = Factory::create(); return sprintf('%s-%s-%d', strtoupper(date('M')), strtoupper($faker->word()), intval($percent)); } }
pour afficher la version d'un package spécifique:
<code>vendor/ composer.lock</code>
Pour plus d'informations sur la CLI, veuillez visiter les sections pertinentes de la documentation.
Résumé
Dans cet article, je présente Gemfury, l'une des nombreuses options de gestion des référentiels privés. En tant que solution de PaaS, il ne nécessite pas le fardeau supplémentaire des options d'auto-hébergement comme Toran et est plus facile à utiliser que les Satis. Il a également l'énorme avantage de prendre en charge les packages dans une variété de langues, des packages PHP Composer à Ruby Gems et Node.js NPM. Bien sûr, en tant que solution de PaaS, elle doit payer pour cela - mais pourquoi ne pas l'essayer avec un essai gratuit ou un plan unique pour voir si cela vous convient?
(La partie FAQ d'origine est omise ici parce que cette partie est une question fréquemment posée, et elle a une répétition élevée du contenu principal de l'article, et sa valeur n'est pas élevée après la pseudo-originalité.)
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!