下面由composer使用教程栏目给大家介绍解析composer.json中所有属性字段,希望对需要的朋友有所帮助!
1、name
包的名字。由供应方(vendor)名和项目名组成,用 / 分隔。
在发布包的时候需要填。
2、description
对包的一个简短描述,通常是一行的长度。
在发布包的时候需要填。
3、version
包的版本。
格式必须是 X.Y.Z,选择性后缀:-dev、-alphaN、-betaN、-RCN。
4、type
包的类型,默认为 library。
包类型用于定制安装逻辑。如果你的包的安装需要一些特殊的逻辑,你可以定义一个定制的类型。它可以是一个 symfony-bundle 的类型,或者 wordpress-plugin,或者 typo3-module。这些类型将被特定的项目所用,它们将提供安装器来安装这些类型的包。
Composer 支持 3 种类型:
library:默认值。它将复制文件到 vendor 目录。
project:它表示这是个项目,而不是库。比如像 Symfony 标准版这种应用。
metapackage:一个含有依赖的空包,能触发安装,但不包含文件,不会向文件系统写任何东西。
composer-install:为其他的定制类型的包提供安装器的包。
5、keywords
一个与包相关的关键词数组。用于包的搜索和过滤。
可选。
6、homepage
项目的网站 URL。
可选。
7、time
版本发布时间。必须是 YYYY-MM-DD 或 YYYY-MM-DD HH:MM:SS 格式。
可选。
8、license
包的许可证。可以是字符串或字符串数组。
可选,但强烈建议加上。
9、authors
包的作者。是个对象数组。
每个 author 对象有这些属性:
name:作者名字
email:作者邮箱
homepage:作者网站 URL
role:作者在项目中的角色(如:developer 或 translator)
10、support
各种关于该项目如何获取支持的信息。包含这些属性:
email:获取支持的邮箱
issues:问题跟踪的 URL
forum:论坛的 URL
wiki:Wiki 的 URL
irc:IRC 的频道
source:查看或下载源码的 URL
可选。
11、Package links
依赖包的映射表,由包名映射版本约束。如:
{ "require": { "monolog/monolog": "1.0.*" } }
(1)require
列出包所依赖的包。除非这些依赖已经存在,否则这个包不会被安装。
(2)require-dev(root-only)
列出开发这个包(或跑测试等等)所依赖的包。在使用 install 命令时,只有带上 “–dev” 参数才能安装 dev 包。在使用 update 命令时,带上 “–no-dev” 则不更新。
(3)conflict
列出包会和哪些包发生冲突。它们将不被允许和你的包一起安装。如果约束了版本,则只会针对特定的版本。
(4)replace
列出哪些包要被这个包替代。
(5)provide
这个包所推荐的包列表。这个对公共接口最有用,一个包可以依赖一个虚拟的 logger 包,而实现 logger 接口的库可以放到 provide 字段中。
12、suggest
建议一些能让这个包工作的更好或得到增强的包列表。这些信息只在包安装完成时给出,暗示用户可以添加更多包,虽然不是必须要安装的。
格式是,包名映射文字说明,如:
{ "suggest": { "monolog/monolog": "Allows more advanced logging of the application flow" } }
13、autoload
提供给 PHP autoloader 的自动加载映射。
目前支持的有:PSR-0 自动加载规范,classmap 生成器,还有 files。
PSR-0 是比较推荐的,因为它的优秀的扩展性(在添加新的类的适合,不需要重新生成自动加载器)。
(1)PSR-0
在 psr-0 键名下,定义一个命名空间到路径的映射表,相对于包的根目录。注意,这也同样支持 PEAR-style 的没有命名空间的风格。
请注意命名空间的声明得以 \\ 结尾,确保自动加载器正确响应。
PSR-0 的引用可以在安装或更新时生成的文件中查看:
vendor/composer/autoload_namespaces.php
例子:
{ "autoload": { "psr-0": { "Monolog\\": "src/", "Vendor\\Namespace\\": "src/", "Vendor_Namespace_": "src/" } } }
如果你需要在多个目录里查找同一个前缀的命名空间,你可以用数组,如:
{ "autoload": { "psr-0": { "Monolog\\": ["src/", "lib/"] } } }
PSR-0 风格并不局限于加载命名空间的声明的东西,也可以用于类这个层级。当库中只有一个在全局命名空间中的类时,这种方式就能用上。比如你有个 PHP 源文件放在项目的根目录,你可以这样声明:
{ "autoload": { "psr-0": { "UniqueGlobalClass": "" } } }
如果你有个目录下全是用命名空间组织的,你可以用空前缀:
{ "autoload": { "psr-0": { "": "src/" } } }
(2)Classmap
classmap 的引用可以在安装或更新时生成的文件中查看:
vendor/composer/autoload_classmap.php
类映射表是通过扫描指定的目录或文件下的所有的 .php 和 .inc 文件生成的。
你可以给任何不支持 PSR-0 的库用 classmap 生成器实现自动加载。配置上只要指定类所在的目录或文件即可:
{ "autoload": { "classmap": ["src/", "lib/", "Something.php"] } }
(3)files
如果你确定需要在任何请求中都加载某些文件,你可以使用 files 自动加载机制。对于那些包中有些 PHP 函数但不能自动加载时特别有用。例如:
{ "autoload": { "files": ["src/MyLibrary/functions.php"] } }
14、include-path
(将被弃用,它的功能由 autoload 代替。其实就是设置 include_path,可选)
15、target-dir
指定安装目标路径。
如果包的根目录是在命名空间下,自动加载就不正确了,所以才有 target-dir 来解决这个问题。
Symfony 就是个例子。它由很多组件包组成。Yaml 组件是在
Symfony\Component\Yaml
命名空间下的,它的根目录是 Yaml 目录。要让自动加载正常工作,我们要确保它不是安装在
vendor/symfony/yaml
,而是在
vendor/symfony/yaml/Symfony/Component/Yaml
,这样自动加载器才能从 vendor/symfony/yaml 加载它。
所以要定义 target-dir 如下:
{ "autoload": { "psr-0": { "Symfony\\Component\\Yaml\\": "" } }, "target-dir": "Symfony/Component/Yaml" }
16、minimum-stability(root-only)
定义根据稳定性如何过滤包。默认是 stable,如果你信赖一个 dev 包,你需要指明。
17、prefer-stable(root-only)
如果开启,Composer 会在稳定包和不稳定包中选择前者。
18、repositories(root-only)
定制包的仓库地址。
默认的,Composer 只使用 Packagist 仓库。通过指定仓库地址,你可以从任何地方获取包。
仓库不能递归。你只能将它们添加到主的 composer.json 中。所依赖包中 composer.json 文件中的仓库定义是被忽略的。
支持的仓库的类型有:
(1)composer
composer 仓库通过网络提供 packages.json 文件,它包含一个 composer.json 对象的列表,还有额外的 dist 或 source 信息。packages.json 文件通过 PHP 流加载。
(2)vcs
版本控制系统仓库,如:git、svn、hg。
(3)pear
通过它,你可以导入任何 pear 仓库到你的项目中。
(4)package
如果你依赖一个不支持 composer 的项目,你可以定义一个 package 类型的仓库,然后将 composer.json 对象直接写入。
完整的例子:
{ "repositories": [ { "type": "composer", "url": "http://packages.example.com" }, { "type": "composer", "url": "https://packages.example.com", "options": { "ssl": { "verify_peer": "true" } } }, { "type": "vcs", "url": "https://github.com/Seldaek/monolog" }, { "type": "pear", "url": "http://pear2.php.net" }, { "type": "package", "package": { "name": "smarty/smarty", "version": "3.1.7", "dist": { "url": "http://www.smarty.net/files/Smarty-3.1.7.zip", "type": "zip" }, "source": { "url": "http://smarty-php.googlecode.com/svn/", "type": "svn", "reference": "tags/Smarty_3_1_7/distribution/" } } } ] }
19、config(root-only)
针对项目的一些配置。
process-timeout:默认 300 秒,Composer 进程执行超时时间; use-include-path:默认 false,如果是 true,Composer 自动加载器也会到 PHP 的 include_path 中查找; preferred-install:默认 auto,设置 Composer 安装方式; github-protocols:默认 [“git”, “https”],设置与 github 通信协议; github-oauth:设置 oauth; vendor-dir:默认 vendor,你可以换成别的; bin-dir:默认 vendor/bin,如果项目有二进制文件,会链接到这; cache-dir:默认 $home/cache,存放 Composer 运行时产生的缓存; cache-files-dir:默认 $cache-dir/files,存放包的 zip 文件; cache-repo-dir:默认 $cache-dir/repo,存放仓库元数据; cache-vcs-dir:默认 $cache-dir/vcs,存放 vcs 克隆; cache-files-ttl:默认六个月,缓存的过期时间; cache-files-maxsize:默认 300M; notify-no-install:默认 true,从仓库安装包会有个通知,可以关掉; discard-changes:默认false,如何处理脏的更新;
20、scripts(root-only)
Composer 允许你在安装进程中安装钩子脚本,钩子是基于事件的;
21、extra
供 scripts 消费的额外数据;
22、bin
指定哪些文件必须被当做二进制文件处理的;
23、archive
设置创建包时的选项,exclude 属性可以设置排除哪些目录,例如:
{ "archive": { "exclude": ["/foo/bar", "baz", "/*.test", "!/foo/bar/baz"] } }
更多composer相关知识,请访问composer栏目:https://www.php.cn/tool/composer/
위 내용은 작곡가.json의 모든 속성 필드를 구문 분석합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성공적인 작곡가가 되려면 음악 이론, 악기 공연 및 사운드 디자인과 같은 기술뿐만 아니라 캡처 및 지속적인 작업 수정에 대한 열렬한 영감이 필요합니다. 작곡가들은 이러한 기술과 특성을 사용하여 감정과 생각을 음악 작품으로 변화시켜 청취자와 공명합니다.

작곡가 숙련도는 다음 4 가지 측면에서 평가 될 수 있습니다. 1) 패키지, 종속성 및 버전 제어와 같은 기본 개념을 이해합니다. 2) Parsing Composer.json, 종속성 해결, 패키지 다운로드 및 자동로드 파일 생성을 포함한 마스터 코어 기능; 3) ComposerInstall, 업데이트, 요구 및 덤프 아우토로드와 같은 기본 및 고급 명령을 사용하는 데 능숙합니다. 4) Composer.Lock 파일 사용, 자동로드 구성 최적화 및 정기적으로 캐시를 정기적으로 청소하는 등 모범 사례를 적용하십시오.

작곡가를 사용하여 AI를 결합하여 자동화 된 작업을 달성하십시오. 1. Composer는 구성 파일을 통해 종속성을 관리하고 AI는 버전 선택을 최적화 할 수 있습니다. 2. 실제 응용 분야에서 AI는 종속성 관리, 테스트 및 배포를 자동화하는 데 사용할 수 있습니다. 3. 성능 최적화에는 의존성 로딩 및 캐싱 전략이 포함됩니다. 4. 버전 충돌 및 AI 잘못 판단과 같은 문제에주의하십시오. 이러한 방법을 통해 AI는 업무 효율성과 지능을 향상시킬 수 있습니다.

ComposerWithai는 AI를 사용하여 프로그래밍 경험을 향상시키는 도구입니다. 1) 코드 구조, 구문 및 패턴을 분석하여 실시간 제안 및 버그 수정을 제공합니다. 2) 고급 기능에는 코드 리팩토링, 성능 최적화 및 보안 검사가 포함됩니다. 3) 사용시 구성을 조정하고 피드백을 제공하며 다른 도구를 결합하여 일반적인 문제를 해결할 수 있습니다.

Composer는 PHP의 종속성 관리 도구로 프로젝트에 필요한 라이브러리 및 패키지를 관리하는 데 사용됩니다. 1) Composer.json 파일을 통한 종속성을 정의합니다. 2) 명령 줄 도구를 사용하여 설치 및 업데이트, 3) 종속성 관리 프로세스 자동화, 개발 효율성 향상, 4) 동적으로 종속성 추가 및 자동로드와 같은 고급 기능을 지원합니다. 5) Composer.lock 파일을 통한 팀 환경의 일관성을 보장합니다.

Composer는 PHP의 종속성 관리 도구이며 Composer.json 및 Composer.lock 파일을 통해 프로젝트 종속성을 관리합니다. 1. Composer.json 파일을 생성하고 ComposerInstall 설치 종속성을 실행하십시오. 2. ComposerRequire를 사용하여 새로운 종속성을 추가하십시오. 3. 자동로드를 구현하도록 자동로드를 구성하십시오. 4. ComposerDiagnose를 사용하여 프로젝트의 건강 상태를 확인하십시오. 5. 종속성 관리 최적화 : 패키지 이름 업데이트를 지정하고, ComposerDump-Autoload-O를 사용하여 자동 로더를 최적화하고, ComposerInstall 사용-생산 환경에서 NO-D

AI와 작곡가의 조합은 PHP 개발 효율성과 보안을 향상시킬 수 있습니다. 특별히 반영 : 1. 종속성 분석 및 최적화 : AI는 종속성을 예측하고 충돌을 줄일 수 있습니다. 2. 자동 보안 점검 : AI는 보안 취약점을 식별 할 수 있으며이를 업데이트하는 것이 좋습니다. 3. 코드 생성 및 최적화 : AI는 관련 코드를 자동으로 생성하고 최적화 할 수 있습니다.

vprocesserazrabotkiveb-enclosed, мнепришлостольносться악 · 뇨 зейейерациигоглапи혁 맥발 추배. LeavallysumballancefriAblancefaumdoMatification, čtookazalovnetakprosto, Kakaožidal.posenesko


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

SecList
SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.

mPDF
mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.

SublimeText3 Linux 새 버전
SublimeText3 Linux 최신 버전

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

DVWA
DVWA(Damn Vulnerable Web App)는 매우 취약한 PHP/MySQL 웹 애플리케이션입니다. 주요 목표는 보안 전문가가 법적 환경에서 자신의 기술과 도구를 테스트하고, 웹 개발자가 웹 응용 프로그램 보안 프로세스를 더 잘 이해할 수 있도록 돕고, 교사/학생이 교실 환경 웹 응용 프로그램에서 가르치고 배울 수 있도록 돕는 것입니다. 보안. DVWA의 목표는 다양한 난이도의 간단하고 간단한 인터페이스를 통해 가장 일반적인 웹 취약점 중 일부를 연습하는 것입니다. 이 소프트웨어는
