目录

  • 介绍
  • 代码规范检查与修复
  • 在git commit时自动检查代码规范
  • 后记

介绍

在团队协作开发中,代码规范是必要的。以前的规范都是自己定,然后手动检查,很难做到有效的约束。

现代的PHP,则有得到广泛认可的编码规范:PSR-1,PSR-2

同时也有配套的包squizlabs/php_codesniffer(下面简称phpcs)可以自动检查代码是否符合规范,并能自动修复部分不规范的代码。

结合brainmaestro/composer-git-hooks,可以进一步做到,在git commit时,强制代码规范的检查。

代码规范检查与修复

安装phpcs包:

composer require squizlabs/php_codesniffer  --dev

这个包,包含了2个工具:

  1. phpcs用于检查代码规范;
  2. phpcbf用于根据代码规范修复代码。

工具位于vendor/bin/目录。

假设要检查app/目录下的代码是否符合规范,执行:

$vendor/bin/phpcs --standard=PSR1,PSR2 app/ routes/ config/

其中,--standard用于指定检查规范时使用的标准,这里使用PSR1和PSR2。而app/,routes/和config/是laravel工程的代码目录。

手动修复代码规范是一件很累人的事情,一般是先通过自动修复,对于修复不成功的再手动修复。执行以下命令可以完成自动修复。

$vendor/bin/phpcbf --standard=PSR1,PSR2 app/ routes/ config/

有些规则,phpcbf无法自动修复,而我们改起来又十分烦琐,可以考虑自定义这些规则。比如上面截图中的一行不能超过120个字符的这条规则,无法被自动修复,但不论是第三方包,还是我们自己写的代码(通常是注释),超过120个字符的非常多,一一修复就太累了。于是修改了该条规则,将数值扩大到240。

具体方法是创建ruleset.xml文件,拷贝以下内容

<?xml version="1.0"?>
<ruleset name="Custom">
<description>Zend, but without linelength check.</description>
<rule ref="Generic.Files.LineLength">
<properties>
<property name="lineLimit" value="240"/>
<property name="absoluteLineLimit" value="0"/>
</properties>
</rule>
</ruleset>

然后在执行代码检查时,在--standard参数附上自定义规则文件路径

$vendor/bin/phpcs --standard=PSR1,PSR2,./ruleset.xml app/ routes/ config/

每次要敲这么长的命令并不方便,一般是写在composer.json中,通过composer lint执行代码检查,通过composer lint-fix修复代码。

要实现这样的效果,修改composer.json, 在scripts增加:

    "scripts": {
// 省略其他部分...
"lint": "phpcs --standard=PSR1,PSR2,./ruleset.xml app/ routes/ config/ ",
"lint-fix": "phpcbf --standard=PSR1,PSR2 app/ routes/ config/ "
}

然后执行composer lintcomposer lint-fix试试。

在git commit时自动检查代码规范

在上一节中,我们已经支持代码规范检查和代码修复。但是实际开发中,常常会忘记要去检查。为了更好的管控流程,最好能在git commit时自动检查,如果不符合规范就停止commit。这就需要使用git的hooks机制,在pre-commit时,执行规范检查和代码修复 。可以直接编辑 .git/hooks/pre-commit,写入在每次git commit之前要执行的脚本。

也可以通过brainmaestro/composer-git-hooks这个包解决此问题,这里使用后面这个方案。

首先安装包:

$composer require brainmaestro/composer-git-hooks

然后编辑composer.json,在extra增加:

    "extra": {
// 省略其他部分...
"hooks": {
"pre-commit": [
"echo committing as $(git config user.name)",
"composer run lint"
]
}
},

写好脚本以后还不能直接使用,需要先通过vendor/bin/cghooks生成.git/hooks/pre-commit

$vendor/bin/cghooks add # 将创建.git/hooks/pre-commit
或者
$vendor/bin/cghooks update ## 将composer.json的内容更新到.git/hooks/pre-commit

如果composer.json与.git不是在同一个目录下,还需要加--git-dir参数,比如vendor/bin/cghooks add --git-dir="../.git"

生成.git/hooks/pre-commit以后,就可以试试,修改一些文件,然后执行git commit看看git hooks有没有被触发。类似下面的执行结果。然后如果有执行错误,会发现git commit不成功。

至此,代码规范的检查就大功告成了。

后记

  1. 其实就是将nodejseslint, husky对应到php版本(没有prettier)。
  2. 有些工程,前端代码和后端代码放在同一个git工程下的不同目录,js那边使用husky自动生成pre-commit钩子,而laravel这边使用了brainmaestro/composer-git-hooks钩子生成了pre-commit,会出现相互覆盖的问题。解决此问题的方法是有2种:一种是创建一个scripts/pre-commit,让开发者在clone工程以后,拷贝到.git/hooks/pre-commit;另一种就是在工程根目录下安装husky,然后在将工程中所有commit之前要做的检查都写入进来。推荐使用第2种方法,husky这个包做得比php这边的包要好用。

laravel代码规范强制检查的更多相关文章

  1. Java-idea-Checkstyle自动化代码规范检查

    一.概述 CheckStyle是SourceForge下的一个项目,提供了一个帮助JAVA开发人员遵守某些编码规范的工具.它能够自动化代码规范检查过程,从而使得开发人员从这项重要,但是枯燥的任务中解脱 ...

  2. 扩展阿里p3c实现自定义代码规范检查

     前段时间fastjson报出了漏洞,只要打开setAutoType特性就会存在风险,自己测试环境的一个项目被揪出来了-_-!.虽然改动很小,但就是觉得憋屈.fastjson还是挺好的,想着禁用的话太 ...

  3. C#零基础入门08:代码规范

    一:前言 没有规矩,不成方圆.在代码的世界中,尤其这样.作为程序员,我们不想让我们的代码写出去之后被人耻笑:看,连个换行都换的这么不专业.作为开发主管,我们则不想我们的组员写出来的代码各类风格都有,五 ...

  4. Java 代码规范,你应该知道的一些工具和用法

    从事编程这个行业,你一定被别人说过或者说过别人这句话:代码要规范!求职面试时也能从 JD 上看到这个要求:要有良好的编程习惯.其实都是在讲代码规范(Code Style)这件事情. 每个人都有自己的编 ...

  5. Java 代码规范,你应该知道的一些工具和用法(转)

    转自:http://yifeng.studio/2017/06/30/coding-with-code-style/ Java 代码规范,你应该知道的一些工具和用法 2017-06-30 从事编程这个 ...

  6. SwiftLint:代码规范检查工具介绍

    Swift-CodeStyle Checker:SwiftLint 介绍: SwiftLint 是一个用于强制检查 Swift 代码风格和规定的一个工具,基本上以 GitHub's Swift 代码风 ...

  7. 转!!Java代码规范、格式化和checkstyle检查配置文档

    为便于规范各位开发人员代码.提高代码质量,研发中心需要启动代码评审机制.为了加快代码评审的速度,减少不必要的时间,可以加入一些代码评审的静态检查工具,另外需要为研发中心配置统一的编码模板和代码格式化模 ...

  8. Java代码规范、格式化和checkstyle检查配置文档

    http://www.blogjava.net/amigoxie/archive/2014/05/31/414287.html 文件下载: http://files.cnblogs.com/files ...

  9. Jenkins系列——使用checkstyle进行代码规范检查【升级版】

    1.背景 在<Jenkins系列——使用checkstyle进行代码规范检查>一文中完成了ant实现代码规范检查的例子.但存在以下缺陷: 每个作业都需要配置一个不同的checkstyle ...

随机推荐

  1. istio流量管理

    目录 1 准备工作 1.1 在k8s部署istio 1.2 istio自动注入 1.3 应用部署要求 2 负载均衡 3 流量迁移:金丝雀发布 3.1 发布应用 3.2 创建目标规则:Destinati ...

  2. 分享几套2019年各大公司最新的PHP面试题,几斤几两一试便知

    从面试题发现不足,进而查漏补缺,比通过面试更难得 PHP面试题2019年奇虎360面试题和答案解析 PHP面试题2019年京东工程师面试题和答案解析 PHP面试题2019年新浪工程师面试题和答案解析 ...

  3. 华为手机usb调试打开后自动关闭怎么办?华为手机 usb调试为什么自动关闭?usb调试老是自动关闭怎么回事?

    01 解决方法一依次点击“设置”——“系统”——“开发人员选项”先开启“开发者选项”开关. 02 然后在开启“USB调试”开关后,一并将“'仅充电'模式下允许ADB调试”选项开关打开.这样,华为手机u ...

  4. Bootstrap初始化过程源码分析--netty客户端的启动

    Bootstrap初始化过程 netty的客户端引导类是Bootstrap,我们看一下spark的rpc中客户端部分对Bootstrap的初始化过程 TransportClientFactory.cr ...

  5. Oracle自定义脱敏函数

    对于信息安全有要求的,在数据下发和同步过程中需要对含有用户身份信息的敏感字段脱敏,包括用户姓名.证件号.地址等等,下面是自定义函数的代码 CREATE OR REPLACE FUNCTION F_GE ...

  6. 06. redis cluster

    目录 Redis Cluster redis cluster 特点 搭建redis cluster 访问redis cluster redis-cli 访问redis cluster 重新分片数据 新 ...

  7. Unity 渲染教程(一):矩阵

    转载:http://gad.qq.com/program/translateview/7181958 创建立方体网格.· 支持缩放.位移和旋转. · 使用变换矩阵. · 创建简单的相机投影. 这是关于 ...

  8. 文件转换神器pandoc

    pandoc  :可以在各种文件之间进行相互转化.比如从md文件转为pdf,docx转为tex文件,html文件和txt文件相互转化,等等. 在终端启用命令行执行命令. 我最近要完成的任务是把有很多个 ...

  9. 遇到libgflags.a(gflags.cc.o): relocation R_X86_64_32 against `.rodata.str1.1' ca时

    glfag编译成动态库gflags 正确的安装方法是这样的: Need cmake >2.8.4 (current is 2.8.3) mkdir build cd build cmake -D ...

  10. Navicat Premium 12 永久使用办法

    1.按步骤安装Navicat Premium,如果没有可以去官网下载:http://www.navicat.com.cn/download/navicat-premium 2.安装好后下载激活文件:h ...