转自 https://www.kancloud.cn/thinkphp/php-fig-psr/3139php
PSR-1基本代码规范thinkphp
PHP代码文件必须以 <?php 或 <?= 标签开始;
PHP代码文件必须以 不带BOM的 UTF-8 编码;
PHP代码中应该只定义类、函数、常量等声明,或其余会产生 从属效应 的操做(如:生成文件输出以及修改.ini配置文件等),两者只能选其一;
命名空间以及类必须符合 PSR 的自动加载规范:PSR-0 或 PSR-4 中的一个;
类的命名必须遵循 StudlyCaps 大写开头的驼峰命名规范;
类中的常量全部字母都必须大写,单词间用下划线分隔;
方法名称必须符合 camelCase 式的小写开头驼峰命名规范。函数
PSR-2代码风格规范编码
代码必须遵循 PSR-1 中的编码规范 。
代码必须使用4个空格符而不是 tab键 进行缩进。
每行的字符数应该软性保持在80个以内, 理论上必定不可多于120个, 但必定不能有硬性限制。
每一个 namespace 命名空间声明语句和 use 声明语句块后面,必须插入一个空白行。
类的开始花括号({)必须写在函数声明后自成一行,结束花括号(})也必须写在函数主体后自成一行。
方法的开始花括号({)必须写在函数声明后自成一行,结束花括号(})也必须写在函数主体后自成一行。
类的属性和方法必须添加访问修饰符(private、protected 以及 public), abstract 以及 final必须声明在访问修饰符以前,而 static必须声明在访问修饰符以后。
控制结构的关键字后必需要有一个空格符,而调用方法或函数时则必定不能有。
控制结构的开始花括号({)必须写在声明的同一行,而结束花括号(})必须写在主体后自成一行。
控制结构的开始左括号后和结束右括号前,都必定不能有空格符。spa
PSR-3日志接口规范debug
LoggerInterface 接口对外定义了八个方法,分别用来记录 RFC 5424 中定义的八个等级的日志:debug、 info、 notice、 warning、 error、 critical、 alert 以及 emergency 。
第九个方法 —— log,其第一个参数为记录的等级。可以使用一个预先定义的等级常量做为参数来调用此方法,必须与直接调用以上八个方法具备相同的效果。若是传入的等 级常量参数没有预先定义,则必须抛出 Psr\Log\InvalidArgumentException 类型的异常。在不肯定的状况下,使用者不应使用未支持的等级常量来调用此方法。日志
以上每一个方法都接受一个字符串类型或者是有 __toString() 方法的对象做为记录信息参数,这样,实现者就能把它当成字符串来处理,不然实现者必须本身把它转换成字 串。
PSR-4自动载入代码规范
完整的类名必需要有一个顶级命名空间,被称为 “vendor namespace”;
完整的类名能够有一个或多个子命名空间;
完整的类名必须有一个最终的类名;
完整的类名中任意一部分中的下滑线都是没有特殊含义的;
完整的类名能够由任意大小写字母组成;
全部类名都必须是大小写敏感的。
当根据完整的类名载入相应的文件……
完整的类名中,去掉最前面的命名空间分隔符,前面连续的一个或多个命名空间和子命名空间,做为“命名空间前缀”,其必须与至少一个“文件基目录”相对应;
紧接命名空间前缀后的子命名空间必须与相应的”文件基目录“相匹配,其中的命名空间分隔符将做为目录分隔符。
末尾的类名必须与对应的以 .php 为后缀的文件同名。
自动加载器(autoloader)的实现必定不能抛出异常、必定不能触发任一级别的错误信息以及不该该有返回值。对象
记录信息参数能够携带占位符,实现者能够根据上下文将其它替换成相应的值。接口