composer is a dependency management tool for PHP. This article will explain how to build a package and submit it to Packagist, so that others can easily use your package through composer.
There are the following steps to develop a composer package:
Initialize the composer.json file
Define the namespace and package name
Function that needs to be implemented to implement the package
Submit to GitHub
Register the package on Packagist
Initialize the composer.json file
After installing composer, you can run it locallycomposer init
Set composer.json through the interactive command line.
The following introduces several of the properties, as well as the general settings:
name
This property defines the package name, separated by /, the preceding one is the supply The vendor name, followed by the package name, is a unique name provided by the vendor representative Packagist website to developers to organize packages and prevent naming conflicts. Therefore, when submitting, it is best to visit https://packagist.org/packages/yourvendorname and replace yourvendorname in the URL with the name you want. If the page does not have 404, it means it has been registered.
license
License. Regarding licenses, it is recommended to read two articles: Introduction to open source project licenses and how to choose license
require
Dependencies required to install the current package. The current package will be installed only if all dependencies are installed.
autoload
This configuration is mainly PSR-4 or PSR-0 settings, and it is more recommended to use the PSR-4 standard.
http://json-schema.org/ The definition of JSON Schema and the implementation of its various functions in various languages are introduced. There is the implementation of validator, among which JSON Schema Validator is an online verification. Serve. In fact, the simplest thing is to use composer validate composer.json
to verify whether the file has errors.
Project structure
The project structure is a typical MVC structure.
. └── geo └── geosso ├── LICENSE ├── README.md ├── composer.json └── src ├── Contracts ├── Http │ ├── Controllers │ ├── Middleware │ └── Requests ├── ParamsBean ├── Providers ├── Support └── config12 directories
LICENSE, README.md and composer.json are manually created after running tree -d
added.
The project root directory is defined under src and is also defined in composer.json, so that when composer loads this package, it knows how to resolve the file path through the namespace.
The Http directory represents the request response, the Controllers below represent the controllers of legal requests, Middleware represents the first level of the request, intercepting the request through middleware, and Requests obtains the front-end request and filters the request.
Contracts represents the interface definition. ParamsBean represents the parameter encapsulation when the application layer communicates with the underlying service. It uses the Bean to obtain each parameter instead of passing an array to make the calls consistent. It also forces type detection when calling the interface, which can largely unify the parameter transfer between layers. .
Providers represents Laravel's service container. Through the service container, you can register routes and configurations, load helper classes, and bind interfaces and their implementations.
Support are some helper classes that encapsulate commonly used functions that have nothing to do with logic. config represents the application's own configuration. Through config, you can easily set the configuration and use the global function config()
transfer.
Submit to GitHub
Follow the previous steps, a package will have a basic skeleton. The next step is to upload it to GitHub, configure the project, integrate the continuous integration service, and issue the open source project license.
GitHub When initializing the project, you can choose to generate a .gitignore file, select a license, initialize the README.md file, switch to the local project directory, and follow the following steps to upload the directory to 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 is the default address for composer to obtain package metadata information. After obtaining the metadata information from Packagist, pull the code from GitHub. Therefore, after uploading the package you develop to GitHub, you need to register it with Packagist so that people all over the world can pull your code through composer.
The above is the detailed content of How to build a wheel with composer. For more information, please follow other related articles on the PHP Chinese website!

PHP is mainly procedural programming, but also supports object-oriented programming (OOP); Python supports a variety of paradigms, including OOP, functional and procedural programming. PHP is suitable for web development, and Python is suitable for a variety of applications such as data analysis and machine learning.

PHP originated in 1994 and was developed by RasmusLerdorf. It was originally used to track website visitors and gradually evolved into a server-side scripting language and was widely used in web development. Python was developed by Guidovan Rossum in the late 1980s and was first released in 1991. It emphasizes code readability and simplicity, and is suitable for scientific computing, data analysis and other fields.

PHP is suitable for web development and rapid prototyping, and Python is suitable for data science and machine learning. 1.PHP is used for dynamic web development, with simple syntax and suitable for rapid development. 2. Python has concise syntax, is suitable for multiple fields, and has a strong library ecosystem.

PHP remains important in the modernization process because it supports a large number of websites and applications and adapts to development needs through frameworks. 1.PHP7 improves performance and introduces new features. 2. Modern frameworks such as Laravel, Symfony and CodeIgniter simplify development and improve code quality. 3. Performance optimization and best practices further improve application efficiency.

PHPhassignificantlyimpactedwebdevelopmentandextendsbeyondit.1)ItpowersmajorplatformslikeWordPressandexcelsindatabaseinteractions.2)PHP'sadaptabilityallowsittoscaleforlargeapplicationsusingframeworkslikeLaravel.3)Beyondweb,PHPisusedincommand-linescrip

PHP type prompts to improve code quality and readability. 1) Scalar type tips: Since PHP7.0, basic data types are allowed to be specified in function parameters, such as int, float, etc. 2) Return type prompt: Ensure the consistency of the function return value type. 3) Union type prompt: Since PHP8.0, multiple types are allowed to be specified in function parameters or return values. 4) Nullable type prompt: Allows to include null values and handle functions that may return null values.

In PHP, use the clone keyword to create a copy of the object and customize the cloning behavior through the \_\_clone magic method. 1. Use the clone keyword to make a shallow copy, cloning the object's properties but not the object's properties. 2. The \_\_clone method can deeply copy nested objects to avoid shallow copying problems. 3. Pay attention to avoid circular references and performance problems in cloning, and optimize cloning operations to improve efficiency.

PHP is suitable for web development and content management systems, and Python is suitable for data science, machine learning and automation scripts. 1.PHP performs well in building fast and scalable websites and applications and is commonly used in CMS such as WordPress. 2. Python has performed outstandingly in the fields of data science and machine learning, with rich libraries such as NumPy and TensorFlow.


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Safe Exam Browser
Safe Exam Browser is a secure browser environment for taking online exams securely. This software turns any computer into a secure workstation. It controls access to any utility and prevents students from using unauthorized resources.

WebStorm Mac version
Useful JavaScript development tools

SAP NetWeaver Server Adapter for Eclipse
Integrate Eclipse with SAP NetWeaver application server.

MinGW - Minimalist GNU for Windows
This project is in the process of being migrated to osdn.net/projects/mingw, you can continue to follow us there. MinGW: A native Windows port of the GNU Compiler Collection (GCC), freely distributable import libraries and header files for building native Windows applications; includes extensions to the MSVC runtime to support C99 functionality. All MinGW software can run on 64-bit Windows platforms.

Atom editor mac version download
The most popular open source editor