Composer は PHP の依存関係管理ツールです。この記事では、他の人が Composer を通じてパッケージを簡単に使用できるように、パッケージを構築して Packagist に送信する方法を説明します。
コンポーザー パッケージを開発するには、いくつかの手順があります。
composer.json ファイルを初期化する
定義名前空間とパッケージ名
パッケージに実装する必要がある機能
GitHub に送信
- Packagist の
パッケージを登録します
composer.json ファイルを初期化します
composer をインストールした後、composer init をローカルで実行し、対話型コマンドを使用して Composer.json を設定できますライン。
次に、いくつかの属性と一般的な設定を紹介します。
name この属性は、/ で区切られたパッケージ名を定義します。前にある属性は、サプライヤー名、パッケージ名に続いて、ベンダーは、パッケージを整理し、名前の競合を防ぐために、Packagist Web サイトによって開発者に提供される一意の名前を表します。したがって、送信するときは、https://packagist.org/packages/yourvendorname にアクセスし、URL 内の yourvendorname を希望の名前に置き換えることをお勧めします。ページに 404 がない場合は、登録されていることを意味します。
ライセンス ライセンス。ライセンスについては、オープンソース プロジェクト ライセンスの概要とライセンスの選択方法
の 2 つの記事を読むことをお勧めします。現在のパッケージをインストールするために必要な依存関係が必要です。現在のパッケージは、すべての依存関係がインストールされている場合にのみインストールされます。
autoload この構成では、主な設定は PSR-4 または PSR-0 です。PSR- を使用することをお勧めします。 4標準。
http://json-schema.org/ では、JSON スキーマの定義とそのさまざまな機能のさまざまな言語での実装が紹介されており、その中には JSON スキーマが含まれます。 Validator はオンライン検証サービスです。実際、最も簡単な方法は、composer validate combos.json を使用して、ファイルにエラーがあるかどうかを確認することです。
これは、composer.json のセットアップ方法を説明するビデオです
プロジェクトの構造
例として、私が開発したシングル サインオン SDK を取り上げます。 Laravel に基づいてサイトを実装します。 シングル サインオン システムに簡単にアクセスするには、アプリケーションをサーバーに登録し、SSO にアクセスするための指定されたインターフェイスを実装するだけで済みます。
プロジェクト構造は典型的な MVC 構造です。
.└── geo └── geosso ├── LICENSE ├── README.md ├── composer.json └── src ├── Contracts ├── Http │ ├── Controllers │ ├── Middleware │ └── Requests ├── ParamsBean ├── Providers ├── Support └── config12 directories
LICENSE、README.md、composer.json は、tree -d の実行後に手動で追加されます。
プロジェクトのルート ディレクトリは src で定義され、composer.json でも定義されているため、composer はこのパッケージを読み込むときに、名前空間を介してファイル パスを解決する方法を認識します。
HTTP ディレクトリはリクエストの応答を表し、以下のコントローラは正当なリクエストのコントローラを表し、ミドルウェアはリクエストの第 1 レベルを表し、ミドルウェアを通じてリクエストを傍受し、フロントエンドのリクエストとフィルタを取得するリクエストを表します。リクエスト。
コントラクトはインターフェース定義を表します。 ParamsBean は、アプリケーション層が基礎となるサービスと通信するときに、配列を渡す代わりに Bean を使用して各パラメーターを取得し、インターフェイスを呼び出すときに型検出を強制するため、パラメーターを大幅に統合できます。レイヤー間の転送。
プロバイダーは Laravel のサービス コンテナーを表し、サービス コンテナーを通じて、ルートと構成を登録し、ヘルパー クラスをロードし、インターフェイスとその実装をバインドできます。
サポートは、ロジックとは関係のない一般的に使用される関数をカプセル化するいくつかのヘルパー クラスです。config を通じて、グローバル関数 config() を使用して構成を簡単に設定および呼び出すことができます。
GitHub に送信
前の手順に従って、パッケージに基本的なスケルトンが作成されます。次の手順では、パッケージを GitHub にアップロードし、プロジェクトを構成し、継続的統合サービスを統合して、オープンソースプロジェクトのライセンス。
GitHub がプロジェクトを初期化するとき、.gitignore ファイルの生成、ライセンスの選択、README.md ファイルの初期化、ローカル プロジェクト ディレクトリへの切り替え、次の手順に従ってディレクトリをアップロードすることを選択できます。 GitHub:
>git init # 初始化仓库>git remote set-url origin --push --add git@github.com:jayxhj/geosso.git # 添加远程追踪仓库地址> git add .> git commit> git push origin master
Submit to Packagist
Packagist は、composer がパッケージのメタデータ情報を取得した後、GitHub からコードをプルします。したがって、開発したパッケージを GitHub にアップロードした後、世界中の人々が Composer を通じてコードをプルできるように、パッケージを Packagist に登録する必要があります。
わずか 3 つのステップで Packagist に送信できます:
https://packagist.org/ でアカウントを登録します
Packages/submit開発パッケージを送信します
送信されたパッケージが更新後に時間内に Packagist に同期できるように Webhook を設定します
それ以降、基本パッケージ 開発は終了しました。 Composer を使用して PHP の依存関係を管理し、コンポーザー パッケージを作成して独自のクラス ライブラリを拡張し、他のクラス ライブラリを導入して独自の関数を補完できるため、車輪を再発明する必要がありません。

phpssionsStrackuserdataacrossmultiplepagerequestsusingauniqueidstoredinacookie.here'showtomanageetheemefectively:1)Startassession withsession_start()andstoredatain $ _ session.2)RegeneratesseSsessidafterloginwithsession_id(the topreventes_id)

PHPでは、次の手順を通じてセッションデータを繰り返すことができます。1。session_start()を使用してセッションを開始します。 2。$ _Sessionアレイのすべてのキー価値ペアを介してforeachループを反復します。 3.複雑なデータ構造を処理する場合、is_array()またはis_object()関数を使用し、print_r()を使用して詳細情報を出力します。 4.トラバーサルを最適化する場合、ページングを使用して、一度に大量のデータの処理を避けることができます。これにより、実際のプロジェクトでPHPセッションデータをより効率的に管理および使用するのに役立ちます。

このセッションは、サーバー側の状態管理メカニズムを介してユーザー認証を実現します。 1)セッションの作成と一意のIDの生成、2)IDはCookieを介して渡されます。3)サーバーストアとIDを介してセッションデータにアクセスします。

tostoreauser'snameInappession、starthessession withsession_start()、thensignthenameto $ _session ['username']。1)ousession_start()toinitializethessession.2)assighttheuser'snameto $ _ session ['username']

PHPSESSIONの障害の理由には、構成エラー、Cookieの問題、セッションの有効期限が含まれます。 1。構成エラー:正しいセッションをチェックして設定します。save_path。 2.Cookieの問題:Cookieが正しく設定されていることを確認してください。 3.セッションの有効期限:セッションを調整してください。GC_MAXLIFETIME値はセッション時間を延長します。

PHPでセッションの問題をデバッグする方法は次のとおりです。1。セッションが正しく開始されるかどうかを確認します。 2.セッションIDの配信を確認します。 3.セッションデータのストレージと読み取りを確認します。 4.サーバーの構成を確認します。セッションIDとデータを出力し、セッションファイルのコンテンツを表示するなど、セッション関連の問題を効果的に診断して解決できます。

session_start()への複数の呼び出しにより、警告メッセージと可能なデータ上書きが行われます。 1)PHPは警告を発し、セッションが開始されたことを促します。 2)セッションデータの予期しない上書きを引き起こす可能性があります。 3)session_status()を使用してセッションステータスを確認して、繰り返しの呼び出しを避けます。

PHPでのセッションライフサイクルの構成は、session.gc_maxlifetimeとsession.cookie_lifetimeを設定することで達成できます。 1)session.gc_maxlifetimeサーバー側のセッションデータのサバイバル時間を制御します。 0に設定すると、ブラウザが閉じているとCookieが期限切れになります。


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

mPDF
mPDF は、UTF-8 でエンコードされた HTML から PDF ファイルを生成できる PHP ライブラリです。オリジナルの作者である Ian Back は、Web サイトから「オンザフライ」で PDF ファイルを出力し、さまざまな言語を処理するために mPDF を作成しました。 HTML2FPDF などのオリジナルのスクリプトよりも遅く、Unicode フォントを使用すると生成されるファイルが大きくなりますが、CSS スタイルなどをサポートし、多くの機能強化が施されています。 RTL (アラビア語とヘブライ語) や CJK (中国語、日本語、韓国語) を含むほぼすべての言語をサポートします。ネストされたブロックレベル要素 (P、DIV など) をサポートします。

SecLists
SecLists は、セキュリティ テスターの究極の相棒です。これは、セキュリティ評価中に頻繁に使用されるさまざまな種類のリストを 1 か所にまとめたものです。 SecLists は、セキュリティ テスターが必要とする可能性のあるすべてのリストを便利に提供することで、セキュリティ テストをより効率的かつ生産的にするのに役立ちます。リストの種類には、ユーザー名、パスワード、URL、ファジング ペイロード、機密データ パターン、Web シェルなどが含まれます。テスターはこのリポジトリを新しいテスト マシンにプルするだけで、必要なあらゆる種類のリストにアクセスできるようになります。

VSCode Windows 64 ビットのダウンロード
Microsoft によって発売された無料で強力な IDE エディター

SublimeText3 中国語版
中国語版、とても使いやすい

WebStorm Mac版
便利なJavaScript開発ツール

ホットトピック









