Yii2中设置与获取别名的函数(setAlias和getAlias)用法

网络编程 2021-07-05 09:10www.168986.cn编程入门
这篇文章主要介绍了Yii2中设置与获取别名的函数(setAlias和getAlias)用法,较为详细的分析了别名的概念、用法及Yii中设置与获取别名的具体实现方法,需要的朋友可以参考下

本文实例讲述了Yii2中设置与获取别名的函数(setAlias和getAlias)用法。分享给大家供大家参考,具体如下

说说什么是别名

在Yii中有很多的路径,在开发的过程当前我们也会使用一些路径。都需要使用绝对路径,但绝对路径都很长。

所以,为了方便的使用路径,可以在Yi中i给每个路径起个名称,这个名称就是别名。

别名的格式

别名必须以"@"字符开头,别名中还可以包含"/"。如("@"为根别名,"@/test"就为子别名)
别名的目录分隔符("\"或者"/")都将去掉(如果有的情况下)

别名的路径有以下几个格式

目录路径或者文件的路径(`/tmp`, `/tmp/main.txt`)
URL(`http://.yii2.`)
另一个别名路径(`@yii/base`),这样会调用getAlias(),解析里面的别名。

设置别名

Yii::setAlias("@", "C:\\");
Yii::setAlias("@data", "C:\\data");
Yii::setAlias("@data/attach", "C:\\data\attach\icon.png");
Yii::setAlias("@home", ".yiifans.\");
Yii::setAlias("@admin", "@\admin");

设置别名的时候,如果路径里面包含别名那么会调用getAlias(),解析里面的别名。
如别名@yii 对应的路径为/xxx/yii,那么@yii/base将会解析为/xxx/yii/base

获取别名

获取别名路径的时候按如下顺序来

如果别名不以"@"开头,直接返回别名,不作处理
查找相匹配的最长的别名,然后用别名路径来替换传入的参数中的别名。

如设置了两个别名"@foo"=>"my""@foo/test"=>"my/test"

如果用@foo/test/config来获取对应的路径,结果为"my/test/config"
如果用@foo/testtst/config来获取对应的路径,结果为"my/testtst/config"
如果用@foo/config来获取对应的路径,结果为"my/config"

即在匹配的时候会以"/"作为分隔符,先匹配最长的别名

上面设置的别名的结果分别为

Yii::getAlias("@");
//输出C:\
Yii::getAlias("@data");
//输出C:\\data
Yii::getAlias("@data/attach");
//输出C:\\data\attach\icon.png
Yii::getAlias("@home");
//输出.yiifans.
Yii::getAlias("@admin");
//输出C:\\admin

设置别名函数源码setAlias

public static function setAlias($alias, $path)
{
 if (strncmp($alias, '@', 1)) {
  //如果不是@开头,则自动在前面加上@
  $alias = '@' . $alias;
 }
 //查找别名中的"/"
 $pos = strpos($alias, '/');
 //如果别名中没有"/",则根别名就是所输入的别名,否则从截取"/"前面的作为根别名
 //如@,根别名就为@;
 //如:@/data,那么根别名截取为@。
 $root = $pos === false ? $alias : substr($alias, 0, $pos);
 if ($path !== null) {
  /
    如果路径中包含有别名,另直接调用getAlias来解析得到路径。
    否则去掉结尾的"/"、"\"
   /
  $path = strncmp($path, '@', 1) ? rtrim($path, '\\/') : static::getAlias($path);
  if (!isset(static::$aliases[$root])) {
   /
     如果还没有设置过这个根别名(@)
    
     如果别名就是根别名(参数就是@),则直接设置别名对应的路径(['@'=>'路径'])
     否则生成路径为一个数组(['@'=>['@/data'=>'路径'])
    
     @   ['@'=>'xxxx']
     @/a   ['@'=>['@/a'=>xxxa]]
     @/b   ['@'=>['@/b'=>xxxb]]
     @/a/b   ['@'=>['@/a/b'=>xxxc]]
    
     注上面的这4中只会注册其中的一个,因为在上面判断了有没有注册@
    /
   if ($pos === false) {
    static::$aliases[$root] = $path;
   } else {
    static::$aliases[$root] = [$alias => $path];
   }
  } elseif (is_string(static::$aliases[$root])) {
   /
     注册过根别名(只有注册过根别名,对应的值才会是字符串)
    
     如果当前注册的是根别名,直接覆盖旧值。
     ['@']=xxx
    
     否则把当前别名和根别名添加到根别名数组中
     @/a  ['@']=['@/a'=>xxxa,'@'=>'xxx']
    
    /
   if ($pos === false) {
    static::$aliases[$root] = $path;
   } else {
    static::$aliases[$root] = [
     $alias => $path,
     $root => static::$aliases[$root],
    ];
   }
  } else {
   //添加到根别名的数组中
   static::$aliases[$root][$alias] = $path;
   krsort(static::$aliases[$root]);
  }
 } elseif (isset(static::$aliases[$root])) {
  //如果是根别名数组,删除子别名。
  if (is_array(static::$aliases[$root])) {
   unset(static::$aliases[$root][$alias]);
  } elseif ($pos === false) {
   //删除整个根别名数组
   unset(static::$aliases[$root]);
  }
 }
}

例如

@=>xxx        ['@']=xxx
@=>yyy        ['@']=yyy
@/a=>yyya      ['@']=['@/a'=>yyya,'@'=>yyy]
@/b=yyyb       ['@']=['@/a'=>yyya,'@'=>yyy,'@/b'=>yyyb]

也就是说,会把所有的相同根别名的数据,放到一个以根别名为键的数组中,而且对键进行逆向排序

获取别名函数源码:getAlias

public static function getAlias($alias, $throwException = true)
{
 //如果不是为@开头,直接返回alias
 if (strncmp($alias, '@', 1)) {
  // not an alias
  return $alias;
 }
 //获取根别名,和setAlias相同
 $pos = strpos($alias, '/');
 $root = $pos === false ? $alias : substr($alias, 0, $pos);
 if (isset(static::$aliases[$root])) {
  //如果根别名的值为字符串,即只设置了一个根别名(['@'=>xxx])
  if (is_string(static::$aliases[$root])) {
   /
     如果获取的名称为根别名,直接返回根别名对应的路径,
     否则返回值为根别名路径+去掉别名之后的路径
    
     如
     @,直接返回 xxx
     @/aaa/bbb 返回xxx/aaa/bbb
    /
   return $pos === false ? static::$aliases[$root] : static::$aliases[$root] . substr($alias, $pos);
  } else {
   / 遍历子别名
    
     @=>xxx  ['@']=xxx
     @=>yyy  ['@']=yyy
     @/a=>yyya  ['@']=['@/a'=>yyya,'@'=>yyy]
     @/b=>yyyb  ['@']=['@/a'=>yyya,'@/b'=>yyyb,'@'=>yyy]
     @/a/c=>yyyac  ['@']=['@/a/c'=>yyyac,'@/a'=>yyya,'@/b'=>yyyb,'@'=>yyy]
    /
   foreach (static::$aliases[$root] as $name => $path) {
    /
      在这里,因为根别名的所有子别名都根据键也就是子别名进行了逆向排序
      所以在查找的时候总是先匹配最长的别名。
     
      又因为在比较的时候给别名后面加了"/",所以可以保证在查找的时候能以"/"作为分隔符。
     /
    if (strpos($alias . '/', $name . '/') === 0) {
     return $path . substr($alias, strlen($name));
    }
   }
  }
 }
 if ($throwException) {
  throw new InvalidParamException("Invalid path alias: $alias");
 } else {
  return false;
 }
}

更多关于Yii相关内容感兴趣的读者可查看本站专题《》、《》、《》、《》、《》、《》及《》

希望本文所述对大家基于Yii框架的PHP程序设计有所帮助。

Copyright © 2016-2025 www.168986.cn 狼蚁网络 版权所有 Power by