编写自己的composer项目
编写自己的composer项目
composer
的出现给php
开发带来极大的便利, 配合phpunit
的测试工具, 也可以更好的规范php开发. 尽管这些标准不是官方提供的, 但现在大部分的php框架几乎都按照这个规范去开发和管理项目. 这里先介绍一下怎么去编写自己的composer
项目
一. 创建github
项目
可以参考我的项目地址 https://github.com/yin32167/cpstpl
config
配置文件存放的位置src
源代码tests
测试文件位置
.gitignore
git忽略文件LICENSE.md
项目许可证README.md
项目介绍composer.json
composer配置文件phpunit.xml
phpunit配置文件
1. 关于.gitignore
配置
执行
composer install
会生成composer.lock
文件, 并将相关的依赖下载到vendor
文件夹, 所以这两个文件是需要忽略的
2. 关于LICENSE.md
内容
这个看大家项目的具体目的, 对于开源项目来讲, 用MIT
协议比较常见
3. 关于README.md
内容
主要是介绍项目基础信息及用法, 项目的github
页面会将内容显示出来, 以markdown
格式
二. 配置 composer
- 安装
composer
:mac
用户可以使用homebrew
,windows
用户可以直接下载安装包安装
https://pkg.phpcomposer.com/#how-to-install-composer
注意确保
composer
命令在环境变量中
- 配置中国镜像: 由于国外镜像速度太慢, 影响开发效率
- 编辑配置文件
require
: 由于composer
是php
的包管理工具, 所以需要依赖php环境, 这里我们建议使用php7
以上版本, 毕竟各方面都有很大的提升require-dev
: 一般加载测试相关的包autoload
: 指定自动加载的文件夹, 现在一般采用psr-4
标准
会生成
composer.lock
及vendor
文件夹. 如果修改了composer.json
, 但之前已经生成了composer.lock
, 此时需要执行composer update
, 配置才能生效
三. 添加 phpunit
- 安装
Windows 用户具体参见 http://www.phpunit.cn/manual/current/zh_cn/installation.html#installation.phar.windows
一定要确保phpunit
在环境变量中
- 编辑配置文件
phpunit.xml
bootstrap
指定启动测试时, 先加载vendor/autoload.php
testsuite
指定测试文件的目录filter
过滤依赖文件的位置
- 执行测试样例
四. 上传到 packagist
- 先注册, 需要关联
github
创建
composer
模块名称, 尽量和github
一致就好检测提交
如果你没按照它的规范, 会提示失败, 并给出原因, 只需按照修改即可.
附:
如果github
中存在多个branch
, 则在生成composer
模块的时候会打包对应dev-分支名
版本号, 如果不希望出现dev
, 也就是看起来是正式版本, 需要在github
打tag
, 此时会以tag
的名称作为版本号而不会加上dev
编写自己的composer项目的更多相关文章
- 用Spring3编写第一个HelloWorld项目
第一个HelloWorld程序 让我们用Spring来写第一个应用程序吧. 完成这一章要求: 熟悉Java语言 设置好Spring的环境 熟悉简单的Eclipse IDE的操作 如果你还没有设置好环境 ...
- PHPUnit 在phpstrom中composer项目的应用配置
在phpstorm的composer搭建的项目调试时出现这种错误时:是其配置的错误 'Cannot create phar '/data/AppStorm/DesignPatternsPHP/vend ...
- 【微信小程序】使用vscode编写微信小程序项目
1. 在微信开发者工具(以下简称:开发者)中新建一个模板微信小程序 2. 在开发者中将模拟器分隔开 3. 设置在保存时编译 4. 在vscode中打开项目目录 5. 下载代码提示插件 这样就可以在vs ...
- Composer项目安装依赖包
说明:一般用Composer的项目中,目录下都有一个composer.json文件,安装这些依赖,只需要输入命令即可 步骤: cmd进入项目目录,运行命令即可 composer install 文章参 ...
- Vue.js结合vue-router和webpack编写单页路由项目
一.前提 1. 安装了node.js. 2. 安装了npm. 3. 检查是否安装成功: 打开cmd,输入node,没有报“node不是内部或外部命令”表示安装成功node.js. 打开cmd,输入np ...
- 编写自己的starter项目(battcn-starter-swagger)
自定义 starter 项目,方便其他地方调用,类似 spring.datasource.url 这种,本次以自己封装的 battcn-starter-swagger 为案例 创建一个Maven工程 ...
- 编写一个飞行棋项目(C#)遇到几个问题:
在写程序中遇到如下问题:如果有人知道,请您一定要指点迷津.小白. 1.在运行暂停功能时,这个暂停功能可以实现,但是无法显示提示信息. case 3: Console.Clear(); Program. ...
- Flutter实战视频-移动电商-02.Flutter实战建立项目和编写入口文件
02.Flutter实战建立项目和编写入口文件 创建项目: flutter create flutter_shop 创建完成之后呢,它会提示我们, 进入flutter_shop的目录,然后执行flut ...
- 手工编写JavaWeb项目
手工编写JavaWeb项目 一.打开Tomcat服务器 二.编写简单的web项目 三.访问项目 并且,tomcat服务器也是可以直接访问.txt的,其实就和其它的web服务器一样,什么都可以访问,和之 ...
随机推荐
- JavaScript数据类型之数字类型
引言 JavaScript不区分整数值和浮点数值,全部使用浮点数值表示.当一个数字直接出现在JavaScript程序中,我们称之为数字直接量(numeric litertal).JavaScript支 ...
- 新近碰到的病毒(TR.Spy.Babonock.A)
先来段Microsoft的说明: Worm:Win32/Babonock.A Alert level: Severe Detected with Windows Defender Antivirus ...
- Nginx使用教程(三):Nginx配置性能优化之I/O和TCP配置
配置Nginx I/O <br\> Sendfile 当应用程序传输文件时,内核首先缓冲数据,然后将数据发送到应用程序缓冲区. 应用程序反过来将数据发送到目的地. Sendfile方法是一 ...
- PHP服务器Apache与Nginx的对比分析
PHP服务器Apache与Nginx的对比分析 本篇文章给大家带来的内容是关于PHP服务器Apache与Nginx的对比分析,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助. Apach ...
- 转://Oracle 数据备份与恢复微实践
1.模拟控制文件丢失后的数据库恢复(完全恢复) 今天的主题是备份与恢复,目的就是保护数据的安全性,众所周知Oracle之所以在市场上占据了50%的份额,与它提供了强大的数据保护措施是分不开的,下面我们 ...
- 004_后端js编写工具
一.框架同事用的后端调试用的工具 google=>"webpack dev server" https://webpack.github.io/docs/webpack-de ...
- 仿照wtform自定义Form组件
仿照wtforms自定义Form组件 1.wtforms 点击查看源码分析及使用方法 2.自定义Form组件 #!usr/bin/env python # -*- coding:utf-8 -*- f ...
- list.remove操作注意点
通过源码分析一下结果public class Test { public static void main(String[] args) { // test1(); // test2(); test3 ...
- day93
虚拟机安装Liunx以及Xshell链接 首先安装VMware虚拟机软件 安装完成后打开会显示 选择创建新的虚拟机 我们选择自定义 来到一个选择虚拟机兼容性 下一步安装客户端操作系统这里我们先选择稍后 ...
- 读写分离子系统 - C# SQL分发子系统 - Entity Framework支持
A2D Framework增加了EF支持,加上原先支持ADO.NET: 支持EF方式 支持ADO.NET方式 这次来讲如何让Entity Framework变成nb的读写分离 1. 先设计EF模型, ...