您好,欢迎访问一九零五行业门户网

结合Composer 新版本PHP的开发方式

一、php的一些臭历史 dependency manager for php,composer。在composer还没诞生之前,php的代码很难被管理。虽然pear社区的支持,许多可重用代码可以通过pear来获得,但是pear在处理代码关联性上非常差,当然还有许多问题。java领域有maven工具, .net 的v
一、php的一些臭历史     dependency manager for php,composer。在composer还没诞生之前,php的代码很难被管理。虽然pear社区的支持,许多可重用代码可以通过pear来获得,但是pear在处理代码关联性上非常差,当然还有许多问题。java领域有maven工具, .net 的vs工具集成了nuget,都是非常好使的关联管理器。但是php何去何从?composer诞生了。它的诞生很大意义上是因为php的3.0版本被普及了,php的命名空间特性让代码包可以在全球级别上具备唯一识别性。当然有人说,我们可以在一个类的命名上做文章也可以做到,但是,会带来许多问题,类名太长,命名重名性高,文件的组织性识别性差等等。php根本无法忽略java,.net一直在被使用的package与命名空间的特性,php必须换血。随着php3.0 的普及,通过众多第三方的努力,php社区迅猛的积累了许多可用的代码库,起初,大部分代码库都是分享在github,采用git的方式获取。虽然这个可取,但是关联管理以及操作性上还是比较差。我们需要一个更加简单的具备关联管理的代码库管理工具。yeah。composer。
     好了,说到这里,或许许多人还很模糊。没关系,我们采用尝试动手,来熟悉composer。
二、初体验composer     composer具体点是什么? 就是一个编译压缩过的phar文件,一个可以执行的工具。
     怎么获取? 
linux下
$ curl -ss https://getcomposer.org/installer | php
windows下
c:\users\username>cd c:\binc:\bin>php -r readfile('https://getcomposer.org/installer'); | php
完了,你可以在控制台下,输入命令 php composer.phar 来获取composer的使用帮助。
下面我们来演示一下,如何使用composer来创建一个php项目
首先,创建一个项目目录composerdemo进入目录之后,使用以上命令来获取composer.phar,当然composer是可以全局配置,意思为不需要一个php项目下载一个composer,而是共用一个composer接下来 调用 php composer.phar init 可以自动创建一个 composer.json文件,当然你也可以手工创建。
{ name: kendoctor/composer_demo, description: introduction for how to use composer, minimum-stability: stable, authors: [ { name: kendoctor, email: kendoctor@163.com } ], require: { }}
这个文件很重要,它告诉composer如何工作。初始创建的模版,你可以修正一些你的项目的信息。
name ,项目名称,命名规则,vendor名称/项目名称description,项目描述minium-stability,版本类型,具体内容参考官方阐述。这里先不作探讨。authors,作者信息。require, 这里可以请求你项目其他的相关php类库或类库包
下面我们来演示composer的第一个特性,类的自动载入   首先,按照目录结构来创建文件
composerdemo/├── composer.phar├── composer.json├── src/│ ├── models│ ├── calculator.php├── index.php
文件calculator.php 我们要使用类calculator,php老办法就是require这个类文件。事实上,我们在代码中会调用许多类,而这些类都会放到不同的文件中,那样的话,我们需要许多的require。我们知道index.php可以这么写
addnumbers(10,21);
但是,这不是我们用了composer想要的。我们要的效果是,实例某个类,它会自动载入。那,怎么搞呢?
修改composer.json
{ name: kendoctor/composer_demo, description: description_text, minimum-stability: stable, authors: [ { name: author's name, email: email@example.com } ], autoload:{ classmap: [src/] }}
require这个属性被我删除了,稍等我们再来介绍其特性。首先这里引入一个autoload属性,可以自动加载类或命名空间的特性属性。classmap属性定义要引入的哪个目录下的类,或者直接可以是类文件。我们这里指定src目录下所有的类文件。修改之后,我们要通过composer命令来更新一下目录结构内容,很简单
php composer.php dump-autoload
完了会自动产生目录vendor,里面许多自动产生的内容,不过这里,我们只需要关注autoload.php这个文件。我们在index.php只需要引入这个文件就可以了addnumbers(10,21);
如果你又新添加了一个user到models目录下,那你无需要做其他工作,就可以直接在index.php文件中直接调用此类了。
其它类似信息

推荐信息