搜尋
首頁開發工具composercomposer的一些學習與理解

composer的一些學習與理解

Apr 23, 2021 pm 04:06 PM
composerlaravelphp

关于composer一些学习和理解

Composer 不是一个包管理器。是的,它涉及 "packages" 和 "libraries",但它在每个项目的基础上进行管理,在你项目的某个目录中(例如 vendor)进行安装。默认情况下它不会在全局安装任何东西。因此,这仅仅是一个依赖管理。

这种想法并不新鲜,Composer 受到了 node's npm 和 ruby's bundler 的强烈启发。而当时 PHP 下并没有类似的工具。

Composer 将这样为你解决问题:

  • 你有一个项目依赖于若干个库。

  • 其中一些库依赖于其他库。

  • 你声明你所依赖的东西。

  • Composer 会找出哪个版本的包需要安装,并安装它们(将它们下载到你的项目中)。

因为laravel是使用composer管理的,所以一切以laravel为基础。

下载安装composer

这里补充的是:

  1. 因为某些原因,访问国外的composer资源网站很慢,导致composer install或者update的时候经常连接超时而出错,所以改为中国镜像

    全局:
    composer config -g repo.packagist composer https://packagist.phpcomposer.com
    
    局部项目(需要在项目当前目录下执行):
    composer config repo.packagist composer https://packagist.phpcomposer.com

执行完命令后会在composer.json文件里面增加这段,这样就代表添加中国镜像成功了,以后执行composer install或者update之类的命令的时候就会优先使用这个镜像

    "repositories": {
      "packagist": {
        "type": "composer",
        "url": "https://packagist.phpcomposer.com"
      }
    }

composer selfupdate来保持composer工具本身的版本更新

关于composer.json文件

{
    "name": "laravel/laravel",
    "description": "The Laravel Framework.",
    "keywords": ["framework", "laravel"],
    "license": "MIT",
    "type": "project",
    "require": {  //这里是告诉composer必须要安装的项目,相当于生产环境
        "php": ">=5.5.9",
        "laravel/framework": "5.2.*",  //require 需要一个 包名称,这个就是包名称
        "laravelcollective/html": "5.2.*",
        "yuanchao/laravel-5-markdown-editor": "dev-master"
    },
    "require-dev": {  //这个是开发需要安装的项目,相当于开发环境,可以通过-no-dev来取消安装这个项目里面的包
        "fzaninotto/faker": "~1.4",
        "mockery/mockery": "0.9.*",
        "phpunit/phpunit": "~4.0",
        "symfony/css-selector": "2.8.*|3.0.*",
        "symfony/dom-crawler": "2.8.*|3.0.*"
    },
    "autoload": {
        "classmap": [
            "database"
        ],
        "psr-4": {
            "App\\": "app/"
        }
    },
    "autoload-dev": {
        "classmap": [
            "tests/TestCase.php"
        ]
    },
    "scripts": {
        "post-root-package-install": [
            "php -r \"copy('.env.example', '.env');\""
        ],
        "post-create-project-cmd": [
            "php artisan key:generate"
        ],
        "post-install-cmd": [
            "Illuminate\\Foundation\\ComposerScripts::postInstall",
            "php artisan optimize"
        ],
        "post-update-cmd": [
            "Illuminate\\Foundation\\ComposerScripts::postUpdate",
            "php artisan optimize"
        ]
    },
    "config": {
        "preferred-install": "dist"
    }
}

包名称的版本

确切的版本号--------1.0.2---------你可以指定包的确切版本。

范围-------->=1.0 >=1.0,=1.0,=1.2--------通过使用比较操作符可以指定有效的版本范围。 有效的运算符:>、>=、=1.0,=1.2,<blockquote><p>我们需要重点关注通配符和波浪符,通配符很好理解,波浪符有点拗口,<code>~ 最好用例子来解释: ~1.2 相当于 >=1.2,=1.2.3,语义化很难懂,但是直接看例子是可以知道怎么用的</code></p></blockquote><h2 id="基本用法">基本用法</h2><p>composer是通过读取composer.json和composer.lock文件来进行安装包的</p><p>在安装依赖后,Composer 将把安装时确切的版本号列表写入 composer.lock 文件。这将锁定改项目的特定版本。<code>因为 install 命令将会检查锁文件是否存在,如果存在,它将下载指定的版本(忽略 composer.json 文件中的定义)。如果不存在 composer.lock 文件,Composer 将读取 composer.json 并创建锁文件。</code></p><p>一般的使用用法有:</p><ol>
<li><p>composer install  (install 命令从当前目录读取 composer.json 文件,处理了依赖关系,并把其安装到 vendor 目录下。)</p></li>
<li><p>composer install XXXX  (这是单独安装某些包的时候使用)</p></li>
<li><p>composer update (为了获取依赖的最新版本,并且升级 composer.lock 文件,)</p></li>
<li>
<p>composer update XXX (类似)</p>
<pre class="brush:php;toolbar:false">--prefer-source: 下载包的方式有两种: source 和 dist。对于稳定版本 composer 将默认使用 dist 方式。而 source 表示版本控制源 。如果 --prefer-source 是被启用的,composer 将从 source 安装(如果有的话)。如果想要使用一个 bugfix 到你的项目,这是非常有用的。并且可以直接从本地的版本库直接获取依赖关系。
--prefer-dist: 与 --prefer-source 相反,composer 将尽可能的从 dist 获取,这将大幅度的加快在 build servers 上的安装。这也是一个回避 git 问题的途径,如果你不清楚如何正确的设置。
--dry-run: 如果你只是想演示而并非实际安装一个包,你可以运行 --dry-run 命令,它将模拟安装并显示将会发生什么。
--dev: 安装 require-dev 字段中列出的包(这是一个默认值)。
--no-dev: 跳过 require-dev 字段中列出的包。
--no-scripts: 跳过 composer.json 文件中定义的脚本。
--no-plugins: 关闭 plugins。
--no-progress: 移除进度信息,这可以避免一些不处理换行的终端或脚本出现混乱的显示。
--optimize-autoloader (-o): 转换 PSR-0/4 autoloading 到 classmap 可以获得更快的加载支持。特别是在生产环境下建议这么做,但由于运行需要一些时间,因此并没有作为默认值。
  • composer require(require 命令增加新的依赖包到当前目录的 composer.json 文件中。但并不即可更新)

  • composer dump-autoload(某些情况下你需要更新 autoloader,例如在你的包中加入了一个新的类。)

  • 自动加载

    composer的自动加载会生产这个文件vendor/autoload.php,然后调用这个文件就能够获得文件里面的类的自动加载

    自动加载只支持 PSR-4和 PSR-0两种命名方式

    Under the psr-4 key you define a mapping from namespaces to paths, relative to the package root. 
    
    {
        "autoload": {
            "psr-4": {
                "Monolog\\": "src/",  //这里写法其实差不多,但是展现的意义并不相同,psr4会设定一个命名空间作为包的根目录,举例这行的意思是src/目录映射成为Monolog\\根目录,那么调用这个包的时候写Monolog\Bar\Baz,其实自动加载就会去这里src/Bar/Baz.php找类文件,然后加载
                "Vendor\\Namespace\\": ""
            }
        }
    }
    
    在 psr-0 key 下你定义了一个命名空间到实际路径的映射(相对于包的根目录)
    {
        "autoload": {
            "psr-0": {
                "Monolog\\": "src/",  //这里的意思是src/目录映射为Monolog\\,如果要调用Monolog\Bar\Baz,那么自动加载就会去src/Monolog/Bar/Baz.php,然后加载
                "Vendor\\Namespace\\": "src/",
                "Vendor_Namespace_": "src/"
            }
        }
    }

    laravel的自动加载会多了一些东西

    vendor/autoload.php
    
    <?php // autoload.php @generated by Composer
    
    require_once __DIR__ . &#39;/composer&#39; . &#39;/autoload_real.php&#39;;  //会再次加载autoload_real.php这个文件,然后获取getLoader,不过总的过程是一样的。
    
    return ComposerAutoloaderInitf1f9a2cafe15aa5cd52ec13394a5f5fb::getLoader();

    引用参考:

    1. http://docs.phpcomposer.com/00-intro.html

    2. https://getcomposer.org/doc/00-intro.md


    以上是composer的一些學習與理解的詳細內容。更多資訊請關注PHP中文網其他相關文章!

    陳述
    本文轉載於:segmentfault。如有侵權,請聯絡admin@php.cn刪除
    作曲家的資格:評估能力作曲家的資格:評估能力Apr 24, 2025 am 12:15 AM

    Composer使用熟練程度可以通過以下四個方面評估:1)理解基礎概念,如包、依賴和版本控制;2)掌握核心功能,包括解析composer.json、解決依賴、下載包和生成autoload文件;3)熟練使用基本和高級命令,如composerinstall、update、require和dump-autoload;4)應用最佳實踐,如使用composer.lock文件、優化autoload配置和定期清理緩存。

    作曲家:利用AI進行自動任務作曲家:利用AI進行自動任務Apr 23, 2025 am 12:03 AM

    使用Composer結合AI可以實現自動化任務。 1.Composer通過配置文件管理依賴,AI可優化版本選擇。 2.在實際應用中,AI可用於自動化依賴管理、測試和部署。 3.性能優化包括依賴加載和緩存策略。 4.需注意版本衝突和AI誤判等問題。通過這些方法,AI能提升工作效率和智能化程度。

    與AI:代碼建議和見解的作曲家與AI:代碼建議和見解的作曲家Apr 22, 2025 am 12:05 AM

    ComposerwithAI是利用AI提升編程體驗的工具。 1)它通過分析代碼結構、語法和模式,提供實時建議和錯誤修復。 2)高級功能包括代碼重構、性能優化和安全性檢查。 3)使用時可調整配置、提供反饋和結合其他工具來解決常見問題。

    作曲家:PHP依賴管理器的簡介作曲家:PHP依賴管理器的簡介Apr 21, 2025 am 12:02 AM

    Composer是PHP的依賴管理工具,用於管理項目所需的庫和包。 1)它通過composer.json文件定義依賴,2)使用命令行工具進行安裝和更新,3)自動化依賴管理過程,提高開發效率,4)支持高級功能如動態添加依賴和自動加載,5)通過composer.lock文件確保團隊環境一致性。

    作曲家的目的:有效地管理依賴關係作曲家的目的:有效地管理依賴關係Apr 20, 2025 am 12:04 AM

    Composer是PHP的依賴管理工具,通過composer.json和composer.lock文件管理項目依賴。 1.創建composer.json文件並運行composerinstall安裝依賴。 2.使用composerrequire添加新依賴。 3.配置autoload實現類自動加載。 4.使用composerdiagnose檢查項目健康狀況。 5.優化依賴管理:指定包名更新,使用composerdump-autoload-o優化自動加載器,生產環境使用composerinstall--no-d

    作曲家和AI:PHP開發中的新可能性作曲家和AI:PHP開發中的新可能性Apr 19, 2025 am 12:03 AM

    AI與Composer結合可提升PHP開發效率和安全性。具體體現在:1.依賴解析和優化:AI可預測依賴關係,減少衝突。 2.自動化安全檢查:AI能識別安全漏洞,建議更新。 3.代碼生成和優化:AI能自動生成和優化相關代碼。

    使用DICR/YII2-Google將Google API集成在YII2中使用DICR/YII2-Google將Google API集成在YII2中Apr 18, 2025 am 11:54 AM

    vProcesserazrabotkiveb被固定,мнелостольностьстьс粹餾標д都LeavallySumballanceFriablanceFaumDoptoMatification,Čtookazalovnetakprosto,kakaožidal.posenesko

    如何使用 Composer 解決 JSON Schema 驗證問題如何使用 Composer 解決 JSON Schema 驗證問題Apr 18, 2025 am 11:51 AM

    在開發一個基於Symfony的應用程序時,我遇到了一個棘手的問題:如何有效地驗證JSON數據格式。最初,我嘗試使用手動編寫的驗證代碼,但這不僅複雜,而且容易出錯。經過一番探索,我發現了一個名為ptyhard/json-schema-bundle的Composer包,它為我的項目帶來了極大的便利和效率。

    See all articles

    熱AI工具

    Undresser.AI Undress

    Undresser.AI Undress

    人工智慧驅動的應用程序,用於創建逼真的裸體照片

    AI Clothes Remover

    AI Clothes Remover

    用於從照片中去除衣服的線上人工智慧工具。

    Undress AI Tool

    Undress AI Tool

    免費脫衣圖片

    Clothoff.io

    Clothoff.io

    AI脫衣器

    Video Face Swap

    Video Face Swap

    使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

    熱工具

    記事本++7.3.1

    記事本++7.3.1

    好用且免費的程式碼編輯器

    Atom編輯器mac版下載

    Atom編輯器mac版下載

    最受歡迎的的開源編輯器

    MinGW - Minimalist GNU for Windows

    MinGW - Minimalist GNU for Windows

    這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。

    禪工作室 13.0.1

    禪工作室 13.0.1

    強大的PHP整合開發環境

    WebStorm Mac版

    WebStorm Mac版

    好用的JavaScript開發工具