PHP的PSR推荐规范,PSR-1,PSR-2,PSR-3,PSR-4详解

 PHP   高蒙   阅读(4149)   评论(0)   2016-03-20 09:36:47    PHP的PSR推荐规范 PSR-1 PSR-2 PSR-3 PSR-4 


PHP的PSR推荐规范,PSR-1,PSR-2,PSR-3,PSR-4详解

PSR是php standards recommendation(php推荐标准)的简称。PHP-FIG制定了每个推荐的规范用于解决大多数php框架经常会遇到的某个具体问题。php框架无需频繁解决相同的问题,他们可以遵守PHP-FIG制定的推荐规范,使用共用的方案来解决。

目前位置,PHP-FIG共发布了5个推荐标准。
PSR-1:基本的代码风格
PSR-2:严格的代码风格
PSR-3:日志记录器接口
PSR-4:自动加载
注意:在这里你可能发现只有四个推荐标准,可是前面你说是五个标准。PHP-FIG废弃了第一份推荐规范PSR-0。第一份推荐标准被新发布的PSR-4替代了。

PSR-1:基本的代码风格

PHP标签:
    必须把php代码放在<?php ?>或<?= ?>标签中。不得使用其他的PHP标签语法。

编码:
    所有PHP文件都必须使用UTF-8字符集编码。

目的:
    一个PHP文件可以定义符号(类、性状、函数和常量等),或者执行有副作用的操作(例如:生成结果或者处理数据),但不能呢个同时做这两件事。这是一个简单的要求,我们只需要深谋远虑一点。

自动加载:
    PHP命名空间和类必须遵守PSR-4自动加载器标准。

类的名称:
    PHP类的名称使用驼峰式。

常量的名称:
    PHP常量的名称必须全部使用大写。

方法的名称:
    PHP方法的名称必须一直使用驼峰式。 

PSR-2:严格的代码风格

在使用PSR-2推荐规范的前提是,必须遵守PSR-1推荐规范。
缩进:
    PSR-2推荐规范要求PHP代码使用4个空格缩进。
    因为,在不同的编辑器中,空格的渲染效果基本一致的,但是制表符却不一致。

文件和代码行:
    PHP文件必须使用UNIX风格的换行符,最后要有一个空行,而且不能使用PHP关闭标签?>。每行代码不能超过80个字符,至少不能超过120字符。每行的末尾不能有空格。
    为什么PHP文件不使用?>关闭标签?
    因为我们不写关闭标签,这样能避免意外的输出错误。如果加上关闭标签?>,而且在关闭标签的后面出现空行,那么这个空行会被当成输出,导致出错。

关键字:
    PSR-2推荐规范要求,PHP关键字都应该使用小写字母。

命名空间:
    每个命名空间声明语句后必须跟着一个空行。

类:
    类定义的结束括号必须在定义体之后新起一行写。如果扩展其他类或实现接口,extends和implements关键字必须和类名写在同一行。

   
    <?php
        namespace my\app

        class Admin extends User
        {
            // 类的定义体
        }

   
方法:
    方法定义体的括号位置和类定义体的括号位置一样:方法定义体的起始括号要在方法名之后新起一行写;方法定义体的结束括号要在定义体之后新起一行写。要特别注意方法的参数;起始圆括号之后没有空格,结束括号之前也没有空格。方法的每个参数(除了最后一个)后面有一个逗号和空格。

    
    <?php
        namespace my\app

        class Admin extends User
        {
             public function AdminLogin($num=1, $name='abc')
             {
               // 方法的定义体   
             }
        }


可见性:
     类中的每个属性和方法都要声明可见性。可见性由public,protected或private指定,其作用是决定在类的内部和外部访问属性和方法。如果把类属性和方法声明为abstract和final,这两个限定符必须放在可见性关键字之前。如果把属性或方法声明为static,这个限定符必须放在可见性关键字之后。

   
    <?php
        namespace my\app

        class Admin
        {
            public static $name =1;
            public function __construct()
            {
                static::$name++;
            }
        } 
 

拓展:


    abstract是什么,怎么使用?

    abstract是抽象的意思。
    1、没有抽象方法的抽象类是没有意义的。
    2、抽象方法在子类中必须重写。
    3、抽象方法在类中,此类必须声明为抽象类。
    4、抽象类中,不能重写父类的抽象方法。

    final是什么,怎么使用?

    final是最终的意思。
    1、final类不可被继承。
    2、final方法不可重写。

    static是什么,怎么使用?

    static是静态的意思。
    1、类中:
        self::属性 self::方法。
    2、子类:
        parent::属性 parent::方法。
    3、外部:
        类名/子类名::属性 类名/子类名::方法

控制结构:

    所有的控制结构关键字的后面都要有一个空格。控制结构关键字包括:if、elseif、else、switch、case、while、do while、for、foreach、try和catch。如果控制结构关键字后面有一对圆括号,起始圆括号后面不能有空格,结束圆括号之前不能有空格。与类和方法的定义体不同,控制结构关键字后面的起始括号应该和控制结构关键字写在同一行。控制结构关键字后面的结束括号必须单独的写一行。

    
    <?php
        if ($a>10) {
         echo "小于10";
        }


PSR-3:日志记录器接口

 PHP-FIG规定的日志记录器其实就是一个接口。PSR-3说接口复用了RFC 5424系统日志协议。
如果你正在准备自己开发日志记录器的话,可以你就别在浪费时间了。因为有个成熟的Monklog组件完全可以实现PSR-3接口,而且便于使用自定义的消息格式化程序和处理程序扩展功能。
Monolog的消息处理程序可以把日志消息写入文本文件,系统日志和数据库,能通过电子邮件发送,还能传给HipChat、Slack、网络中的服务器和远程API。只要你能想到的日志处理方式Monolog几乎提供了。如果Monolog没有你需要的处理程序,你也可以自己编写程序,并将其集成到Monolog中。


示例:将日志消息写入文本文件中。

<?php

use Monolog\Logger;
use Monolog\Handler\StreamHandler;

// 准备日志记录器
$log = new Logger('name');
$log->pushHandler(new StreamHandler('path/warning.log', Logger::WARNING));
$log->pushHandler(new StreamHandler('path/debug.log', Logger::DEBUG));

// 使用日志记录器
$log->debug('yes');
$log->warning('yes');

如果想更深的了解那么就可以看看,博客中《PHP日志记录器Monolog日志记录工具》这篇文章。

 PSR-4:自动加载器

PHP-FIG发布的第四个推荐规范就是描述一个标准的自动加载器。自动加载器的策略就是依赖PHP命名空间和文件系统目录结构查找并加载PHP类、接口和性状。
那么,如何去编写PSR-4规范的自动加载器呢。

<?php

    sql_auto_register(function ($class)) {
       
 // 命名空间的前缀
        $prefix = 'mysqlapp';   

 // 这个命名空间对应的基目录
 $base_dir = __DIR__.'/src/';   

 // 获取传入的类名,是否使用的是这个命名空间前缀
 $len = strlen($prefix);  
 
 // 不使用,交给注册的下一个自动加载器处理
 if (strncmp($class,$prefix,$len) !== 0) {   
     return;
 }

 // 获取去掉前缀后的类名
 $relative_class = substr($class,$len);   

 // 把命名空间前缀换成基目录,将命名空间的分隔符替换成目录分隔符,然后加上.php文件的后缀。
 $file = $base_dir . str_replace('\\','/',$relative_class).'.php';   
        
 // 如果文件存在,将其导入。
 if (file_exitst($file)) {
     require $file;
 }   
    }

这段代码就是可用的PSR-4自动加载器了。如果你想自己编写自动加载器,那么请你停下来,因为,我们可以使用依赖管理器composer自动生成PSR-4自动加载器。

总结:
    目前位置,PHP的PSR推荐规范以及对PSR-1,PSR-2,PSR-3,PSR-4的详解,就到此为止,希望对你有所帮助。




相关文章



我要评论


站长昵称:(*)

输入内容:


评论列表


高蒙

男,程序猿一枚

 

人生要是没有理想, 那跟一条咸鱼有什么分别。


关于我

  http://www.shuchengxian.com

高蒙个人博客是以PHP技术为主的程序员个人博客。博客主要发布php开发中遇到的问题以及解决办法,同时个人博客也分享网站模板素材,jquery插件等方面素材。


站点声明:相关侵权、举报、投诉及建议等,请发E-mail:936594075#qq.com(#替换成@)。

Copyright © 2018, www.shuchengxian.com, All rights reserved. 个人博客皖公网安备 34152302000022号 皖ICP备15015490号

关键词:个人博客,PHP博客,PHP博客程序,高蒙博客,高蒙个人博客,php程序员博客,程序员个人博客