Composer版本依赖

@bruce  March 10, 2020

基本约束

精确版本

可以指定具体的版本,告诉Composer只能安装这个版本。但是如果其他的依赖需要用到其他的版本,则包的安装或者更新最后会失败并终止。

{
    "require": {
        "ezimuel/ringphp": "1.1.2",
    }
}

范围

使用比较操作符可以指定包的范围。这些操作符包括:>,>=,<,<=,!=。 可以定义多个范围,使用空格或者逗号表示逻辑上的与,使用双竖线表示逻辑上的或。其中与的优先级会大于或。也可用连字符定义范围。

需要注意的是,使用没有边界的范围有可能会导致安装不可预知的版本,并破坏向下的兼容性。建议使用折音号操作符。
{
    "require": {
        "ezimuel/ringphp": ">=1.1.2",
        "ezimuel/ringphp": ">=1.1.2 <2.0 || >2.3.0",
        "ezimuel/ringphp": "1.0.0 - 2.1.0",
    }
}

通配符

可使用通配符去定义版本。

{
    "require": {
        "ezimuel/ringphp": "1.1.*",
    }
}

下一个重要版本操作符

波浪号~

波浪号\~定义了最小的版本,并且允许按版本的最后一位版本号进行升级。如\~1.2相当于>=1.2 <2.0.0,而\~1.2.3相当于>=1.2.3 <1.3.0

折音号^

^操作符允许升级版本到安全的版本。

{
    "require": {
        "ezimuel/ringphp": "^1.1.2",
    }
}

版本稳定性

如果没有显式的指定版本的稳定性,Composer会默认在内部指定为-dev或者-stable。如果想指定稳定版本,可以在版本后面添加后缀-stable。 Composer的minimum-stability配置项定义了包在选择版本时对稳定性的选择的默认行为。默认是stable。它的值如下(按照稳定性排序):dev,alpha,beta,RC和stable。除了修改这个配置去修改这个默认行为,还可以通过稳定性标识(例如@stable和@dev)来安装一个相比于默认配置不同稳定性的版本。例如:

{
    "require": {
        "monolog/monolog": "1.0.*@beta",
        "acme/foo": "@stable"
    }
}

添加新评论