How to build a wheel with composer
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!

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

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics



Laravel is a PHP framework for easy building of web applications. It provides a range of powerful features including: Installation: Install the Laravel CLI globally with Composer and create applications in the project directory. Routing: Define the relationship between the URL and the handler in routes/web.php. View: Create a view in resources/views to render the application's interface. Database Integration: Provides out-of-the-box integration with databases such as MySQL and uses migration to create and modify tables. Model and Controller: The model represents the database entity and the controller processes HTTP requests.

When developing websites using CraftCMS, you often encounter resource file caching problems, especially when you frequently update CSS and JavaScript files, old versions of files may still be cached by the browser, causing users to not see the latest changes in time. This problem not only affects the user experience, but also increases the difficulty of development and debugging. Recently, I encountered similar troubles in my project, and after some exploration, I found the plugin wiejeben/craft-laravel-mix, which perfectly solved my caching problem.

I had a tough problem when working on a project with a large number of Doctrine entities: Every time the entity is serialized and deserialized, the performance becomes very inefficient, resulting in a significant increase in system response time. I've tried multiple optimization methods, but it doesn't work well. Fortunately, by using sidus/doctrine-serializer-bundle, I successfully solved this problem, significantly improving the performance of the project.

The Laravel framework has built-in methods to easily view its version number to meet the different needs of developers. This article will explore these methods, including using the Composer command line tool, accessing .env files, or obtaining version information through PHP code. These methods are essential for maintaining and managing versioning of Laravel applications.

I encountered a common but tricky problem when developing a large PHP project: how to effectively manage and inject dependencies. Initially, I tried using global variables and manual injection, but this not only increased the complexity of the code, it also easily led to errors. Finally, I successfully solved this problem by using the PSR-11 container interface and with the power of Composer.

When developing a Laravel application, I encountered a common but difficult problem: how to improve the security of user accounts. With the increasing complexity of cyber attacks, a single password protection is no longer enough to ensure the security of users' data. I tried several methods, but the results were not satisfactory. Finally, I installed the wiebenieuwenhuis/laravel-2fa library through Composer and successfully added two-factor authentication (2FA) to my application, greatly improving security.

When developing an e-commerce platform, it is crucial to choose the right framework and tools. Recently, when I was trying to build a feature-rich e-commerce website, I encountered a difficult problem: how to quickly build a scalable and fully functional e-commerce platform. I tried multiple solutions and ended up choosing Fecmall's advanced project template (fecmall/fbbcbase-app-advanced). By using Composer, this process becomes very simple and efficient. Composer can be learned through the following address: Learning address

When developing an e-commerce website, I encountered a difficult problem: how to provide users with personalized product recommendations. Initially, I tried some simple recommendation algorithms, but the results were not ideal, and user satisfaction was also affected. In order to improve the accuracy and efficiency of the recommendation system, I decided to adopt a more professional solution. Finally, I installed andres-montanez/recommendations-bundle through Composer, which not only solved my problem, but also greatly improved the performance of the recommendation system. You can learn composer through the following address:
