Composer学习

Composer简介

Composer 是 PHP 的一个依赖管理工具。它允许你申明项目所依赖的代码库,它会在你的项目中为你安装他们。
详细参考【Composer基本用法】,此处只记录几个自己常用的方法以及概念。

正所谓年少不识composer,老来看码全是泪。虽然composer已经出来很久,但是由于之前一直没有机会真正深入了解学习,每次写代码需要使用代码库时,都是Ctrl + C然后Ctrl + V,后来渐渐开始学习了解后,发现是真的好用。初入Composer的世界,望大神们多多指点。
有兴趣的同学,可以下载composer.phar来看看里面的源码。简单来说,composer其实就是使用composer.json来对项目包进行管理(括包内容和版本号的统一),除了可以引入线上包以外,可以引入自己开发的包。


1. 核心文件 composer.json

所有参数可参见res/composer-schema.json

composer.json 常用属性解析:

name

包的名称,它包括供应商名称和项目名称,使用 / 分隔。

description

包描述。

type

包的安装类型,默认为 library。
composer原生支持4种类型:libraryprojectmetapackagecomposer-plugin,也可以自定义类型,用得偏多的是library以及project两种:

  • library:这是默认类型,它会简单的将文件复制到 vendor 目录。
  • project:这表示当前包是一个项目,而不是一个库。可以配合 extra 属性使用,定义一些框架中的参数,对项目进行初始化,例如 Thinkphp 中, ThinkFramework.php 文件使用到 $extra['think-path'] ,则可以在 extra 中设置 think-path 属性。
keywords

该包相关的关键词的数组。这些可用于搜索和过滤。

homepage

项目主页。

license

包的许可协议,它可以是一个字符串或者字符串数组。
具体每个协议,可以参照阮一峰大神画的:

![许可协议](https://img-blog.csdn.net/20180822140536272?watermark/2/text/aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L0Rlc3RpbnlMb3JkQw==/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70)
authors

作者信息。

require

整个 composer.json 的核心属性,通过该属性引入所需要依赖的包,需要 包名称 (例如 topthink/framework) 映射到 包版本 (例如 5.1.*) 的对象。【具体包版本使用方法

require-dev

这个列表是为开发或测试等目的,额外列出的依赖。例如PHPUnit(单元测试)、Mockery(用得较少,也是一种测试框架),一般正式环境会使用 composer--no-dev 参数来跳过这些包。

repositories

也是 composer.json 的核心属性之一,该属性用于使用自定义的包资源库。一般企业开发存在不允许外泄的内部包,通过发布到为git的私有项目后,可以使用该属性配置后,拉取到各个项目中去使用。
支持以下类型的包资源库(更多请查看【资源库】):

  • composer: 一个 composer 类型的资源库,是一个简单的网络服务器(HTTP、FTP、SSH)上的 packages.json 文件,它包含一个 composer.json 对象的列表,有额外的 dist 和/或 source 信息。这个 packages.json 文件是用一个 PHP 流加载的。你可以使用 options 参数来设定额外的流信息。
  • vcs:从 git、svn 和 hg 取得资源。
  • pear:从 pear 获取资源。
  • package:如果你依赖于一个项目,它不提供任何对 composer 的支持,你就可以使用这种类型。你基本上就只需要内联一个 composer.json 对象。

2. 锁文件 composer.lock

此文件中的代码,各位没必要深究,也是一些 Json ,而这个文件的主要作用,用于锁定项目当前使用的包版本,对于线上项目来说,是非常重要的。由于在 composer.json 中,有部分 require 进来的包是使用范围的方式引入,执行 composer update 后,所有包当前引入的具体版本号会在 composer.lock 文件中显示具体的版本号,此时我们可以将这些固定版本号回写到 composer.json 中去,这样做可以避免某些包更新后,导致线上正式版本发生未知错误,而且会非常难定位错误的情况。


3. 自动加载 autoload

对于库的自动加载信息,Composer 生成了一个 vendor/autoload.php 文件。在这个文件中,会引用 autoload_real.php文件,在 composer install/update 过程中,符合要求的引入会被以键值对的形式写入对应文件中,其部分核心代码:

/* 该文件用于自定义加载遵循 PSR-0 规范的类库 */
$map = require __DIR__ . '/autoload_namespaces.php';
foreach ($map as $namespace => $path) {
    $loader->set($namespace, $path);
}

/* 该文件用于自定义加载遵循 PSR-4 规范的类库 */
$map = require __DIR__ . '/autoload_psr4.php';
foreach ($map as $namespace => $path) {
    $loader->setPsr4($namespace, $path);
}

/* 该文件用于自定义加载不遵循 PSR-0/4 规范的类库 */
$classMap = require __DIR__ . '/autoload_classmap.php';
if ($classMap) {
    $loader->addClassMap($classMap);
}

除此之外,还有 autoload_files 以及 autoload_static 引入方式。


4. 引入自己的项目包

GIt除了可以通过将代码发布到 Packagist 后再下载,也可以直接通过自己私有的GIt目录去下载项目。以前可能大部分项目,都会通过接口的方式去处理两个模块之前的数据对接,其实很多情况下,可以通过Composer去拉取关联两个项目,可以减少很多网络传输以及减少人员对接接口的成本,是个不错的方案。打个比方:商城项目需要一个登录操作,这个登录操作可能支持Pc端、微信端、小程序端,以前的做法就是将登录操作剥离成为一个单独的项目,在这个项目中处理这些登录(包括Session、Cookie、Cache等)的逻辑以及一些业务上的处理,并且需要加上大量的防攻击、验证、加密等操作,而Pc端、微信端、小程序端也需要专门有一个对登录的操作模块去处理相同的东西。然而现在可以通过Composer,将登录模块作为项目中的一个模块拉取,可以减少很多重复性的工作。拉取方式如官网:

{
    "name": "xxx/login",
    "repositories": [
        {
            "type": "vcs",
            "url": "https://github.com/username/login"
        }
    ],
    "require": {
        "xxx//login": "dev-master"
    }
}

将登录模块的各种校验和逻辑直接作为一个函数方法去封装,直接在程序内部调用即可。

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值