使用“composer outdated”查找过时的 Composer 依赖项
来源:dev.to
时间:2024-08-24 11:25:05 173浏览 收藏
积累知识,胜过积蓄金银!毕竟在文章开发的过程中,会遇到各种各样的问题,往往都是一些细节知识点还没有掌握好而导致的,因此基础知识点的积累是很重要的。下面本文《使用“composer outdated”查找过时的 Composer 依赖项》,就带大家讲解一下知识点,若是你对本文感兴趣,或者是想搞懂其中某个知识点,就请你继续往下看吧~
介绍
构建 php web 应用程序时,保持依赖项最新并防止安装具有已知安全漏洞的 composer 依赖项非常重要。这可以帮助您确保您的应用程序是安全的,并且您可以从最新的功能和错误修复中受益。
但是,在一般日常开发任务之间的依赖关系更新上确实很容易落后。值得庆幸的是,composer 为我们提供了一个方便的工具,您可以使用它来概述您正在使用的软件包有可用的更新。
在这篇 quickfire 文章中,我们将快速浏览一下 composer outdated 命令,以帮助您找到 php 项目中过时的包。
“作曲家过时”命令
您可以运行composer outdated 命令来查找您的哪些依赖项有可用更新。
您可以通过在 php 项目的根目录中运行以下命令来执行命令:
composer outdated
默认情况下,该命令将显示具有可用更新版本的软件包以及您正在使用的当前版本。依赖项分为两个不同的类别:
- 直接依赖项 - 这些是您在composer.json 文件中所需的包。
- 传递依赖项 - 这些是您的直接依赖项所需的包,但不是您直接需要的。
如果依赖项是次要版本或补丁版本,composer 将以红色显示新版本。如果依赖项的主要版本可用,新版本将以黄色显示。
这是运行composer outdated 命令时可能看到的输出示例:
正如我们在图像中看到的,composer outdated 命令已显示具有较新版本可用的软件包。
因此,在上面的示例中,我们可以看到我们在composer.json 文件中所需的 phpunit/phpunit 依赖项当前为 10.5.17,并且有一个主要版本升级到 11.3.1。
我们还可以看到我们有一些传递依赖项,这些依赖项具有可用的主要、次要和补丁升级。
命令选项
composer outdated 命令有几个选项可用于过滤输出:
- 全部
您可以使用 --all 选项来显示项目中的所有依赖项,包括最新的依赖项。如果您想在一个地方查看项目中的所有依赖项并大致了解哪些包需要更新以及哪些包正在运行最新版本,这会很有用。
你可以像这样使用它:
composer outdated --all
输出可能看起来像这样:
如果版本号显示为绿色,则表示我们当前安装的版本是当前最新版本。作为示例,我们可以看到 jonpurvis/profanify 依赖项是最新的。
顺便说一句,我实际上有一篇文章介绍了如何在 php 项目中使用 profanify 来防止代码中出现脏话。您可以在这里查看:profanify:防止 php 代码库中出现脏话
- 直接的
您可以使用 --direct 选项仅显示项目中的直接依赖项。
如果您只想查看 composer.json 文件中直接需要的包,这会很有用。
你可以像这样使用它:
composer outdated --direct
输出可能看起来像这样:
--仅主要
如果您只想查看具有可用主要版本的软件包,可以使用 --major-only 选项。
你可以像这样使用它:
composer outdated --major-only
--仅次要
如果您只想查看有可用次要版本的软件包,可以使用 --minor-only 选项。
你可以像这样使用它:
composer outdated --minor-only
--仅补丁
如果您只想查看有可用补丁版本的软件包,可以使用 --patch-only 选项。
你可以像这样使用它:
composer outdated --patch-only
结论
希望本文能让您快速了解 composer 过时命令以及如何使用它来查找 php 项目中的过时包。
如果您喜欢阅读这篇文章,您可能有兴趣查看我的 220 多页电子书“battle ready laravel”,其中更深入地涵盖了类似的主题。
或者,您可能想查看我的另一本 440 多页电子书“consuming apis in laravel”,它教您如何使用 laravel 来使用来自其他服务的 api。
如果您有兴趣在我每次发布新帖子时获得更新,请随时订阅我的时事通讯。
继续创造精彩的东西! ?
今天关于《使用“composer outdated”查找过时的 Composer 依赖项》的内容介绍就到此结束,如果有什么疑问或者建议,可以在golang学习网公众号下多多回复交流;文中若有不正之处,也希望回复留言以告知!
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
315 收藏
-
417 收藏
-
127 收藏
-
304 收藏
-
177 收藏
-
122 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 507次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 484次学习