recherche
Maisondéveloppement back-endtutoriel phpPackages de compositeurs privés avec Gemfury

Private Composer Packages with Gemfury

Points clés

  • GEMFURY est une solution de plate-forme en tant que service (PAAS) pour héberger des forfaits de compositeurs privés, offrant une alternative aux options d'auto-hébergement telles que Toran Proxy ou Satis. Il prend en charge plusieurs langues, notamment le package PHP Composer, Ruby Gems, Node.js NPM, Python PYPI, APT, YUM et NU-GET.
  • Pour utiliser Gemfury, vous devez créer un compte, créer un package et le télécharger sur la plate-forme. Cela peut être fait en utilisant Git et en faisant gérer Gemfury le reste, ou en zippant manuellement le code source du package et en le téléchargeant sur le tableau de bord Gemfury.
  • Vous pouvez ajouter votre référentiel privé au fichier 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.
  • Gemfury fournit également un outil de ligne de commande pour gérer vos packages. Cet outil vous permet de répertorier vos packages, d'afficher les versions de packages spécifiques, etc. Vous pouvez l'installer en utilisant la commande 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>
Comme vous pouvez le voir, nous créons un package simple avec un seul Faker de dépendance.

Ensuite, ajoutons une ligne au nouveau créé

et disons-le où trouver le code source du package. composer.json

"autoload": {        
    "psr-0": {
        "Acme\": "src/"
    }
},
Créons maintenant le package lui-même. Nous allons créer une classe avec un seul objectif; générer des codes de réduction pour les plates-formes de commerce électronique à l'aide d'algorithmes propriétaires complexes et top secrets.

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));
    }

}
Exécutez maintenant

pour charger nos seules dépendances et configurer l'autoloader. composer install

C'est le package que nous avons construit. Maintenant, téléchargez-le sur Gemfury.

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>
Initialiser le référentiel maintenant:

git init
Ajouter un fichier:

git add src
git add composer.json
Maintenant, nous allons ajouter un référentiel distant GIT. Vous pouvez trouver l'URL pertinente en sélectionnant le démarrage du tableau de bord Gemfury, puis en sélectionnant l'onglet PHP Composer. Cela ressemblera à ceci:

<code>https://your-username@git.fury.io/your-username/<package-name>.git</package-name></code>
Assurez-vous de remplacer

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
À ce stade, vous avez deux choix. La première consiste à utiliser le contrôle de version explicite, où vous spécifiez la version dans le fichier

, 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"
Quelle que soit la méthode que vous prenez, l'étape suivante consiste à soumettre:

git commit -a -m "Initial commit"
Enfin, exécutez la commande suivante:

git push fury master --tags
Cela pousse votre code à Gemfury, qui le construira ensuite automatiquement dans un package.

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>
C'est

qui le rend imprévisible et est donc en fait privé. SECRET-CODE

Ajoutez-le maintenant aux

: 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!

Déclaration
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Comment PHP identifie-t-il la session d'un utilisateur?Comment PHP identifie-t-il la session d'un utilisateur?May 01, 2025 am 12:23 AM

Phpidentifiesauser'sessionusingssse cookiesand sessionids.1) whenSession_start () est calculé, phpgeneratesauquesseSessionIdStoredInacookIenameDPhpSesssIdonUser'sbrowser.2) thisIdallowsphptoreTrrieSeSessionDatafromTeserver.

Quelles sont les meilleures pratiques pour sécuriser les séances PHP?Quelles sont les meilleures pratiques pour sécuriser les séances PHP?May 01, 2025 am 12:22 AM

La sécurité des sessions PHP peut être obtenue grâce aux mesures suivantes: 1. Utilisez Session_RegeReate_ID () pour régénérer l'ID de session lorsque l'utilisateur se connecte ou est une opération importante. 2. Cryptez l'ID de session de transmission via le protocole HTTPS. 3. Utilisez session_save_path () pour spécifier le répertoire sécurisé pour stocker les données de session et définir correctement les autorisations.

Où les fichiers de session PHP sont-ils stockés par défaut?Où les fichiers de session PHP sont-ils stockés par défaut?May 01, 2025 am 12:15 AM

PhpSessionFilesArestorentheDirectorySpecifiedSession.save_path, généralement / tmponunix-likesystemsorc: \ windows \ temponwindows.tocustomzethis: 1) usession_save_path () tosetacustomDirectory, astumeit'swrit

Comment récupérer les données d'une session PHP?Comment récupérer les données d'une session PHP?May 01, 2025 am 12:11 AM

ToretrrievedatafromaphpSession, startTheSessionwithSession_start () et accessvariablesInthe $ _sessionArray.forexample: 1) startTheSession: session_start (). 2) récupéré: $ username = $ _ session ['userSeger']; echo "bienvenue,". $ Username;..

Comment pouvez-vous utiliser des sessions pour mettre en œuvre un panier?Comment pouvez-vous utiliser des sessions pour mettre en œuvre un panier?May 01, 2025 am 12:10 AM

Les étapes pour construire un système de panier d'achat efficace à l'aide de sessions comprennent: 1) Comprendre la définition et la fonction de la session. La session est un mécanisme de stockage côté serveur utilisé pour maintenir l'état de l'utilisateur entre les demandes; 2) Implémenter la gestion de session de base, comme l'ajout de produits au panier; 3) développer une utilisation avancée, soutenant la gestion de la quantité de produits et la suppression; 4) Optimiser les performances et la sécurité, en persistant les données de session et en utilisant des identifiants de session sécurisés.

Comment créez-vous et utilisez-vous une interface dans PHP?Comment créez-vous et utilisez-vous une interface dans PHP?Apr 30, 2025 pm 03:40 PM

L'article explique comment créer, mettre en œuvre et utiliser des interfaces dans PHP, en se concentrant sur leurs avantages pour l'organisation du code et la maintenabilité.

Quelle est la différence entre crypte () et mot de passe_hash ()?Quelle est la différence entre crypte () et mot de passe_hash ()?Apr 30, 2025 pm 03:39 PM

L'article traite des différences entre crypt () et mot de passe_hash () dans PHP pour le hachage de mot de passe, en se concentrant sur leur implémentation, leur sécurité et leur aptitude aux applications Web modernes.

Comment pouvez-vous prévenir les scripts inter-sites (XSS) en PHP?Comment pouvez-vous prévenir les scripts inter-sites (XSS) en PHP?Apr 30, 2025 pm 03:38 PM

L'article discute de la prévention des scripts inter-sites (XSS) dans PHP par validation d'entrée, en codage de sortie et en utilisant des outils comme OWASP ESAPI et Purificateur HTML.

See all articles

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

Video Face Swap

Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Outils chauds

Version crackée d'EditPlus en chinois

Version crackée d'EditPlus en chinois

Petite taille, coloration syntaxique, ne prend pas en charge la fonction d'invite de code

PhpStorm version Mac

PhpStorm version Mac

Le dernier (2018.2.1) outil de développement intégré PHP professionnel

Listes Sec

Listes Sec

SecLists est le compagnon ultime du testeur de sécurité. Il s'agit d'une collection de différents types de listes fréquemment utilisées lors des évaluations de sécurité, le tout en un seul endroit. SecLists contribue à rendre les tests de sécurité plus efficaces et productifs en fournissant facilement toutes les listes dont un testeur de sécurité pourrait avoir besoin. Les types de listes incluent les noms d'utilisateur, les mots de passe, les URL, les charges utiles floues, les modèles de données sensibles, les shells Web, etc. Le testeur peut simplement extraire ce référentiel sur une nouvelle machine de test et il aura accès à tous les types de listes dont il a besoin.

Navigateur d'examen sécurisé

Navigateur d'examen sécurisé

Safe Exam Browser est un environnement de navigation sécurisé permettant de passer des examens en ligne en toute sécurité. Ce logiciel transforme n'importe quel ordinateur en poste de travail sécurisé. Il contrôle l'accès à n'importe quel utilitaire et empêche les étudiants d'utiliser des ressources non autorisées.

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP