composer php 扩展,如何用composer开发自己的php扩展包

下面由composer使用教程栏目给大家介绍用composer开发自己的php扩展包的方法,希望对需要的朋友有所帮助!

d8de1beab126f51c2e2430616d85231a.png

composer 是PHP用来管理依赖关系的工具详情可以阅读:https://www.phpcomposer.com/

安装 见 https://www.phpcomposer.com/

开发流程

初始化自己的扩展包 composer init$ composer init

Welcome to the Composer config generator

This command will guide you through creating your composer.json config.

Package name (/) [administrator/self_composer]: victor/composer-self //包名称-不能大写,否则无效

Description []: composer-self package //描述

Author [victor24680 <490319148@qq.com>, n to skip]://作者

Minimum Stability []: dev //最小稳定版本

Package Type (e.g. library, project, metapackage, composer-plugin) []: library //类型

License []: MIT

Define your dependencies.

Would you like to define your dependencies (require) interactively [yes]? n //是否定义依赖关系

Would you like to define your dev dependencies (require-dev) interactively [yes]? n

{

"name": "victor/composer-self",

"description": "This is a composer-send package",

"type": "victor",

"license": "MIT",

"authors": [

{

"name": "victor24680",

"email": "490319148@qq.com"

}

],

"minimum-stability": "dev",

"require": {}

}

Do you confirm generation [yes]? yes

修改自己包的依赖关系,修改内容如下{

"name": "victor/sendtool-package",

"description": "sendtool package",

"type": "victor",

"license": "MIT",

"authors": [

{

"name": "victor24680",

"email": "490319148@qq.com"

}

],

"minimum-stability": "dev",

"require": {

"php": ">=5.6" //php版本要求

},

"autoload": {

"psr-4": { //加载规范

"App\\": "src/App",

"Contract\\": "src/Contract"

}

}

}

编写好源码 见:https://github.com/victor24680/self-composer/tree/master/src

安装测试 composer install$ composer install

Loading composer repositories with package information

Updating dependencies (including require-dev)

Content-Length mismatch, received 37487 bytes out of the expected 2005372

http://packagist.org could not be fully loaded, package information was loaded from the local cache and may be out of date

Nothing to install or update

Writing lock file

Generating autoload files

GitHub上创建composer-self仓库git init

git add .

git commit -m "初始自己的组件库"

git remote add origin https://github.com/victor24680/self-composer.git

git push origin master

Packagist 上提交自己的github创建的composer-self仓库地址

注册地址:https://packagist.org/,提交成功之后,就可以开始下面的测试

测试 ,A目录代表项目根目录

创建一个A目录,然后在项目根目录下执行:composer require victor24680/self-composer dev-master$ composer require victor24680/self-composer dev-master

./composer.json has been updated

Loading composer repositories with package information

Updating dependencies (including require-dev)

Package operations: 1 install, 0 updates, 0 removals

- Installing victor24680/self-composer (dev-master 0935c75): Cloning 0935c75eda from cache

Writing lock file

Generating autoload files

#项目根目录/index.php

include "vendor/autoload.php";

use App\CommonInfo;

use App\Zn;

$app=new CommonInfo(new Zn());

echo $app->msg('小明','隔壁老王在偷吃!!!');

//输出:【站内消息】发送给:小明|发送内容:【普通消息】隔壁老王在偷吃!!!

至此,一个完整的自己的composer组件包,开发完成。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Laravel 扩展开发可以让你将一些常用的功能打成可复用的模块,方便在自己或者其他人的项目中使用。下面是一个简单的 Laravel 扩展开发流程: 1. 创建扩展 使用 Composer 命令行工具创建一个新的 Laravel 扩展: ``` composer create-project --prefer-dist laravel/laravel my-package ``` 其中,`my-package` 为你的扩展名称。 2. 编写代码 在 `my-package` 目录下,编写你的扩展代码。通常情况下,你需要创建 `src` 目录,并在其中创建扩展的入口文件,例如 `MyPackage.php`。在这个文件中,你可以定义扩展的服务提供者、门面等组件。 3. 注册服务提供者 在 `config/app.php` 文件中注册你的服务提供者,例如: ``` 'providers' => [ // ... MyPackage\MyPackageServiceProvider::class, ], ``` 4. 发布资源文件 如果你的扩展含一些资源文件,例如配置文件、视图文件等,你需要将这些资源文件发布到 Laravel 应用程序中。你可以在服务提供者的 `boot` 方法中使用 `publishes` 方法来完成这个过程,例如: ``` public function boot() { $this->publishes([ __DIR__.'/path/to/config' => config_path('my-package.php'), ], 'config'); } ``` 这个方法会将 `path/to/config` 目录下的配置文件发布到 Laravel 应用程序的 `config` 目录下。 5. 编写测试 为你的扩展编写测试是很重要的。你可以创建 `tests` 目录,并在其中编写你的测试代码。可以使用 PHPUnit 测试框架来运行测试。 6. 发布扩展 当你完成了扩展开发和测试,你可以将其发布到 Packagist 上,以便其他人可以使用 Composer 安装你的扩展。你需要在 Packagist 上注册一个账户,并按照相关文档的说明来发布你的扩展。 以上就是一个简单的 Laravel 扩展开发流程。当然,实际开发中可能会涉及到更多的细节和问题,需要根据具体情况进行处理。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值