백엔드 개발 PHP 튜토리얼 Gemfury가있는 개인 작곡가 패키지

Gemfury가있는 개인 작곡가 패키지

Feb 19, 2025 am 09:19 AM

Private Composer Packages with Gemfury 키 포인트

Gemfury는 개인 작곡가 패키지를 호스팅하기위한 플랫폼-서비스 (PAAS) 솔루션으로 Toran Proxy 또는 Satis와 같은 자체 호스팅 옵션에 대한 대안을 제공합니다. PHP 작곡가 패키지, Ruby Gems, Node.js NPM, Python Pypi, Apt, Yum 및 Nu-Get을 포함한 여러 언어를 지원합니다. gemfury를 사용하려면 계정을 만들고 패키지를 만들고 플랫폼에 업로드해야합니다. 이것은 git을 사용하고 Gemfury가 나머지를 처리하거나 패키지의 소스 코드를 수동으로지고 Gemfury 대시 보드에 업로드하여 수행 할 수 있습니다.

프로젝트의
    파일에 개인 저장소를 추가 할 수 있습니다. 이를 통해 패키지를 사용할 때마다 별도의 저장소를 추가하지 않고 Gemfury로 만든 개인 작곡가 패키지를 사용할 수 있습니다.
  • gemfury는 또한 패키지를 관리하는 명령 줄 도구를 제공합니다. 이 도구를 사용하면 패키지, 특정 패키지의 버전보기 등을 나열 할 수 있습니다. 명령 를 사용하여 설치할 수 있습니다.
  • Composer에 익숙하다고 가정합니다. 이것은 최신의 PHP 패키지 관리자입니다. 그렇지 않다면 Alexander의 소개를 확인하면 즉시 매료 될 것입니다. 이 기사를 최대한 활용하려면 실무 지식이 필요합니다.
  • Composer는 포괄적 인 공개 패키지 저장소 인 Packagist와 효율적이고 완벽하게 작동합니다.
  • 그러나 조만간 자신이 쓴 패키지를 만나게 될 것입니다. composer.json 이 개인 패키지를 호스팅하기위한 몇 가지 옵션이 있습니다. 패키지의 저장소를 개별적으로 추가하여 프로젝트의
  • 파일을 구성 할 수 있습니다. 또는 Satis를 사용하면 고유 한 정적 저장소를 생성 할 수 있습니다. 또는 Toran Proxy를 사용하면 한 번 설정하면 에 저장소를 지정하는 것보다 관리하기 쉬운 자체 호스팅 개인 버전의 Packagist 버전을 만들 수 있습니다.
  • Gemfury는 PAAS 대안입니다. 호스팅 된 솔루션이 PHP 작곡가 패키지뿐만 아니라 Ruby Gems, Node.js NPM, Python Pypi, Apt, Yum 및 NU를 지원한다는 큰 이점입니다. -얻다. 여러 언어가있는 경우 매우 유용합니다. sudo gem install gemfury 사용 방법에 대해 다이빙합시다.
계정을 설정하십시오

우선 계정이 필요합니다. 14 일의 시험 기간이 있으며, 무료 계정은 한 공동 작업자와 호스팅 패키지로 제한되며 한 달에 9 달러부터 시작합니다.

이메일 주소 또는 github 계정을 사용하여 등록 할 수 있습니다. 등록하려면 웹 사이트로 이동하십시오.

첫 번째 패키지를 만듭니다

개인 작곡가 패키지에 Gemfury를 사용하는 방법을 보여 주려면 나중에 다른 프로젝트에서 사용하기 위해 서비스에 제출할 패키지를 단계별로 만들어 봅시다.

새 패키지를 만드는 가장 쉬운 방법은 다음 명령을 사용하는 것입니다.

composer init
로그인 후 복사
로그인 후 복사
는 일련의 질문을 묻습니다

보시다시피, 우리는 하나의 종속성 페이커만으로 간단한 패키지를 만들고 있습니다.

<'s> 다음으로, 새로 만든
<code>...  (此处省略与原文相同的composer init交互过程) ...</code>
로그인 후 복사
로그인 후 복사
에 줄을 추가하고 패키지의 소스 코드를 어디에서 찾을 수 있는지 알려주겠습니다.

이제 패키지 자체를 만들어 봅시다. 복잡한 최고 비밀 독점 알고리즘을 사용하여 전자 상거래 플랫폼에 대한 할인 쿠폰 코드를 생성하는 클래스를 생성합니다.

작업 디렉토리에서 디렉토리를 작성한 다음 <🎜 🎜> : <🎜 🎜>라는 다음 파일을 만듭니다. composer.json

실행 지금 실행하여 유일한 종속성을로드하고 자동 로더를 구성하십시오.
"autoload": {        
    "psr-0": {
        "Acme\": "src/"
    }
},
로그인 후 복사
이것은 우리가 만든 패키지입니다. 이제 Gemfury에 업로드하십시오.

계속하려면 API 키가 필요합니다. 대시 보드로 이동하면 설정 아래에서 찾을 수 있습니다.

패키지를 빌드하고 업로드하는 가장 쉬운 방법은 단순히 git을 사용하고 Gemfury가 나머지를 처리하도록하는 것입니다.

<<> 먼저 다음 내용이있는 src 파일을 만듭니다. src/Acme 지금 저장소를 초기화하십시오 : <🎜 🎜> Coupon.php <<> 파일 추가 : <🎜 🎜>

이제 우리는 git 원격 저장소를 추가합니다. Gemfury 대시 보드에서 시작한 다음 PHP Composer 탭을 선택하여 관련 URL을 찾을 수 있습니다. 다음과 같이 보일 것입니다 : <🎜 🎜>
<?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));
    }

}
로그인 후 복사

를 Gemfury 사용자 이름으로 바꾸십시오 (GitHub에 등록하는 경우 GitHub 사용자 이름과 동일합니다). composer install 이 시점에서 두 가지 선택이 있습니다. 첫 번째는 <🎜 🎜> 파일의 버전을 지정하는 명시 적 버전 컨트롤을 사용하는 것입니다.

시맨틱 버전을 사용하는 것이 중요합니다. 그렇지 않으면 패키지가 올바르게 구축되지 않을 수 있습니다.

또는 git 태그를 사용할 수 있습니다. 예를 들어 아래 그림과 같이 태그로 새 버전을 만듭니다.

어떤 방법을 사용하든 다음 단계는 다음 단계를 제출하는 것입니다.

마지막으로 다음 명령을 실행하십시오

이것은 코드를 Gemfury로 푸시하여 자동으로 패키지로 빌드됩니다.

이제 대시 보드로 이동하면 새 저장소가 나열되어 있음을 알 수 있습니다. 다음으로 프로젝트에서 어떻게 사용하는지 살펴 보겠습니다. .gitignore 개인 패키지 사용

<<
<code>vendor/
composer.lock</code>
로그인 후 복사
<<> 대시 보드로 돌아가서 왼쪽에서 "Repos"를 선택하면 개인 저장소 URL을 찾을 수 있습니다. 이것은 비공개로 유지해야하므로 안전하게 유지하십시오. 다음과 같이 보일 것입니다 : <🎜 🎜>

git init
로그인 후 복사
는 예측할 수 없게 만들어서 실제로 비공개입니다.

지금 프로젝트의 <🎜

: <🎜 🎜>에 추가하십시오
composer init
로그인 후 복사
로그인 후 복사
gemfury와 함께 만든 개인 작곡가 패키지를 사용하려면이 리포지토리를 추가하면됩니다. 패키지를 사용할 때마다 별도의 저장소를 추가 할 필요가 없습니다.

이제 Packagist에서와 마찬가지로 개인 패키지가 필요할 수 있습니다. 다음은 프로젝트의 완전한 예입니다.
<🎜 🎜> <<> 기타 방법

<🎜 🎜> 개인적으로, 나는 git과 태그를 사용하는 것이 패키지를 관리하는 가장 쉽고 효과적인 방법이라고 생각합니다. composer.json 또는 원하는 경우 패키지의 소스 코드를지고 Gemfury 대시 보드에 업로드하여 직접 구축 할 수 있습니다.

<🎜 🎜> <<> 명령 줄 도구
<code>...  (此处省略与原文相同的composer init交互过程) ...</code>
로그인 후 복사
로그인 후 복사
gemfury는 또한 명령 줄 도구를 제공합니다. 설치하려면 :

패키지를 나열하려면 다음 명령을 사용할 수 있습니다. 특정 패키지의 버전을 보려면 : CLI에 대한 자세한 내용은 문서의 관련 섹션을 방문하십시오.

요약

이 기사에서는 개인 리포지토리 관리를위한 많은 옵션 중 하나 인 Gemfury를 소개합니다. PAAS 솔루션으로서, 그것은 Toran과 같은 자조 옵션의 추가 부담이 필요하지 않으며 Satis보다 사용하기 쉽습니다. 또한 PHP 작곡가 패키지에서 Ruby Gems 및 Node.js NPM에 이르기까지 다양한 언어로 패키지를 지원할 때 큰 이점이 있습니다. 물론, PAAS 솔루션으로서 비용을 지불해야합니다. 그러나 무료 평가판이나 무료 단일 패키지 계획을 가지고 시도해 보지 않겠습니까?

(원래 FAQ 부분은 자주 묻는 질문이기 때문에 여기서 생략되어 있으며, 기사의 주요 내용이 높은 반복을 가지고 있으며 의사 원리 후에 그 가치가 높지 않습니다.)

위 내용은 Gemfury가있는 개인 작곡가 패키지의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

JWT (JSON Web Tokens) 및 PHP API의 사용 사례를 설명하십시오. JWT (JSON Web Tokens) 및 PHP API의 사용 사례를 설명하십시오. Apr 05, 2025 am 12:04 AM

JWT는 주로 신분증 인증 및 정보 교환을 위해 당사자간에 정보를 안전하게 전송하는 데 사용되는 JSON을 기반으로 한 개방형 표준입니다. 1. JWT는 헤더, 페이로드 및 서명의 세 부분으로 구성됩니다. 2. JWT의 작업 원칙에는 세 가지 단계가 포함됩니다. JWT 생성, JWT 확인 및 Parsing Payload. 3. PHP에서 인증에 JWT를 사용하면 JWT를 생성하고 확인할 수 있으며 사용자 역할 및 권한 정보가 고급 사용에 포함될 수 있습니다. 4. 일반적인 오류에는 서명 검증 실패, 토큰 만료 및 대형 페이로드가 포함됩니다. 디버깅 기술에는 디버깅 도구 및 로깅 사용이 포함됩니다. 5. 성능 최적화 및 모범 사례에는 적절한 시그니처 알고리즘 사용, 타당성 기간 설정 합리적,

세션 납치는 어떻게 작동하며 PHP에서 어떻게 완화 할 수 있습니까? 세션 납치는 어떻게 작동하며 PHP에서 어떻게 완화 할 수 있습니까? Apr 06, 2025 am 12:02 AM

세션 납치는 다음 단계를 통해 달성 할 수 있습니다. 1. 세션 ID를 얻으십시오. 2. 세션 ID 사용, 3. 세션을 활성 상태로 유지하십시오. PHP에서 세션 납치를 방지하는 방법에는 다음이 포함됩니다. 1. 세션 _regenerate_id () 함수를 사용하여 세션 ID를 재생산합니다. 2. 데이터베이스를 통해 세션 데이터를 저장하십시오.

확실한 원칙과 PHP 개발에 적용되는 방법을 설명하십시오. 확실한 원칙과 PHP 개발에 적용되는 방법을 설명하십시오. Apr 03, 2025 am 12:04 AM

PHP 개발에서 견고한 원칙의 적용에는 다음이 포함됩니다. 1. 단일 책임 원칙 (SRP) : 각 클래스는 하나의 기능 만 담당합니다. 2. Open and Close Principle (OCP) : 변경은 수정보다는 확장을 통해 달성됩니다. 3. Lisch의 대체 원칙 (LSP) : 서브 클래스는 프로그램 정확도에 영향을 미치지 않고 기본 클래스를 대체 할 수 있습니다. 4. 인터페이스 격리 원리 (ISP) : 의존성 및 사용되지 않은 방법을 피하기 위해 세밀한 인터페이스를 사용하십시오. 5. 의존성 반전 원리 (DIP) : 높고 낮은 수준의 모듈은 추상화에 의존하며 종속성 주입을 통해 구현됩니다.

phpstorm에서 CLI 모드를 디버그하는 방법은 무엇입니까? phpstorm에서 CLI 모드를 디버그하는 방법은 무엇입니까? Apr 01, 2025 pm 02:57 PM

phpstorm에서 CLI 모드를 디버그하는 방법은 무엇입니까? PHPStorm으로 개발할 때 때때로 CLI (Command Line Interface) 모드에서 PHP를 디버그해야합니다 ...

프레임 워크 보안 기능 : 취약점 보호. 프레임 워크 보안 기능 : 취약점 보호. Mar 28, 2025 pm 05:11 PM

기사는 입력 유효성 검사, 인증 및 정기 업데이트를 포함한 취약점을 방지하기 위해 프레임 워크의 필수 보안 기능을 논의합니다.

시스템 재시작 후 UnixSocket의 권한을 자동으로 설정하는 방법은 무엇입니까? 시스템 재시작 후 UnixSocket의 권한을 자동으로 설정하는 방법은 무엇입니까? Mar 31, 2025 pm 11:54 PM

시스템이 다시 시작된 후 UnixSocket의 권한을 자동으로 설정하는 방법. 시스템이 다시 시작될 때마다 UnixSocket의 권한을 수정하려면 다음 명령을 실행해야합니다.

PHP에서 늦은 정적 결합을 설명하십시오 (정적 : :). PHP에서 늦은 정적 결합을 설명하십시오 (정적 : :). Apr 03, 2025 am 12:04 AM

정적 바인딩 (정적 : :)는 PHP에서 늦은 정적 바인딩 (LSB)을 구현하여 클래스를 정의하는 대신 정적 컨텍스트에서 호출 클래스를 참조 할 수 있습니다. 1) 구문 분석 프로세스는 런타임에 수행됩니다. 2) 상속 관계에서 통화 클래스를 찾아보십시오. 3) 성능 오버 헤드를 가져올 수 있습니다.

See all articles