Heim  >  Artikel  >  Backend-Entwicklung  >  Detaillierte Beispiele für URL- und Routing-Funktionen von thinkphp5

Detaillierte Beispiele für URL- und Routing-Funktionen von thinkphp5

小云云
小云云Original
2017-12-27 14:17:073576Durchsuche

In diesem Artikel werden hauptsächlich die detaillierten Erklärungen und Beispiele der URL- und Routing-Funktionen von thinkphp5 vorgestellt. Der Herausgeber findet ihn recht gut, daher werde ich ihn jetzt mit Ihnen teilen und als Referenz verwenden. Folgen wir dem Herausgeber und schauen wir uns das an. Ich hoffe, es kann allen helfen.

URL-Zugriff

ThinkPHP verwendet einen Einzeleingabemodus für den Zugriff auf die Anwendung. Alle Anfragen für die Anwendung werden an die Eintragsdatei der Anwendung weitergeleitet Das System greift über die URL-Parameter auf das Modul, den Controller und den Betrieb der aktuellen Anfrage zu. Das Folgende ist ein Standard-URL-Zugriffsformat:


http://domainName/index.php/模块/控制器/操作

wobei index.php als Eintragsdatei der Anwendung bezeichnet wird (Beachten Sie, dass die Eintragsdatei ausgeblendet werden kann, was später erwähnt wird). Das Konzept des Moduls

in ThinkPHP ist eigentlich ein Unterverzeichnis unter dem Anwendungsverzeichnis und Die offizielle Spezifikation besagt, dass der Verzeichnisname in Kleinbuchstaben geschrieben ist, sodass alle Module in Kleinbuchstaben benannt werden. Unabhängig davon, ob die Groß-/Kleinschreibung in der URL aktiviert ist, wird der Modulname in Kleinbuchstaben geschrieben

Der Index-Controller von Das Indexmodul der Anwendung ist wie folgt definiert:


<?php
namespace app\index\controller;
class Index
{
  public function index()
  {
    return &#39;index&#39;;
  }
  public function hello($name = &#39;World&#39;)
  {
    return &#39;Hello,&#39; . $name . &#39;!&#39;;
  }
}

Wenn direkt beim Zugriff auf die Eintragsdatei, da die URL keine Module, Controller und Operationen enthält, Das System greift auf die Standardoperation (Index) des Standardcontrollers (Index) unter dem Standardmodul (Index) zu, daher sind die folgenden Zugriffe gleichwertig:

http://tp5.com/index.php
http://tp5.com/index.php/index/index/index

Wenn Sie auf die Hello-Methode des Controllers zugreifen möchten, müssen Sie die vollständige URL-Adresse

http://tp5.com/index.php/index/index/hello/name/thinkphp

Nach dem Zugriff auf die URL-Adresse lautet das Seitenausgabeergebnis:

Hallo, thinkphp!

Da der Namensparameter ein optionaler Parameter ist, können Sie auch

http://tp5.com/index.php/index/index/ hallo

Nach dem Zugriff verwenden Nach der URL-Adresse lautet das Ergebnis der Seitenausgabe:

Hallo Welt!

Standardmäßig wird bei den Controller- und Operationsnamen in der URL-Adresse die Groß-/Kleinschreibung nicht beachtet, sodass die folgenden Zugriffe tatsächlich gelten Äquivalent:

http://tp5.com/index.php/index/Index/Index

http://tp5.com/index.php/ index/INDEX/INDEX

Wenn es sich bei dem Controller beispielsweise um einen Camel Case handelt, definieren Sie einen HelloWorld-Controller (application/index/controller/HelloWorld.php):


<?php
namespace app\index\controller;
class HelloWorld
{
  public function index($name = &#39;World&#39;)
  {
    return &#39;Hello,&#39; . $name . &#39;!&#39;;
  }
}
Die richtige URL-Zugriffsadresse (Die Adresse kann mit der URL-Methode generiert werden) sollte

http://tp5.com/index.php/index/hello_world/index

System sein. Der HelloWorld-Controller wird automatisch gefunden Klasse zum Betrieb

Wenn Sie

http://tp5.com/index.php/index/HelloWorld/index

verwenden, wird ein Fehler gemeldet, und fordert Sie auf, dass die Helloworld-Controller-Klasse nicht vorhanden ist

Wenn Sie einen strikten Zugriff unter Berücksichtigung der Groß- und Kleinschreibung wünschen (damit die Camel-Case-Methode für den Controller-Zugriff unterstützt werden kann), können Sie dies in der Anwendungskonfigurationsdatei festlegen:


// 关闭URL自动转换(支持驼峰访问控制器)
&#39;url_convert&#39; => false,
Nachdem Sie die automatische URL-Konvertierung deaktiviert haben, müssen Sie für den Zugriff die folgende URL-Adresse verwenden (der Controller-Name muss unbedingt den Namen der Controller-Klasse verwenden, mit Ausnahme des Controller-Suffixes). ):

http://tp5.com/index.php/index/Index/index

http://tp5.com/index.php/index/HelloWorld/index

Wenn die Serverumgebung die Pathinfo-Methode nicht unterstützt. Für den URL-Zugriff können Sie kompatible Methoden verwenden, wie zum Beispiel:

http://tp5.com/index.php?s=/index/Index/index

Der Name der Variable s kann sein. Die Konfiguration

5.0 unterstützt keinen normalen URL-Zugriff mehr, daher ist der folgende Zugriff ungültig. Sie werden feststellen, dass Sie darauf zugreifen, egal was Sie eingeben der Standard-Controller und -Betrieb

http ://tp5.com/index.php?m=index&c=Index&a=hello

Parameter werden übergeben

Durch die Parameterbindungsfunktion der Betriebsmethode können Sie die Parameter der URL automatisch abrufen. Nehmen wir weiterhin den obigen Controller als Beispiel, lautet der Controller-Code wie folgt:


<?php
namespace app\index\controller;
class Index
{
  public function index()
  {
    return &#39;index&#39;;
  }
  public function hello($name = &#39;World&#39;)
  {
    return &#39;Hello,&#39; . $name . &#39;!&#39;;
  }
}
Wenn wir

http://tp5.com/index.php/index/index/hello

besuchen, greifen wir auf die Hello-Methode des appindexcontrollerIndex zu Da keine Parameter übergeben werden, verwendet der Namensparameter den Standardwert World. Wenn der Namensparameter übergeben wird, verwenden Sie:

http://tp5.com/index.php/index/index/hello/name/thinkphp

Das Ergebnis der Seitenausgabe ist:

Hallo, thinkphp!

Fügen Sie nun einen zweiten Parameter zur Hallo-Methode hinzu:


public function hello($name = &#39;World&#39;, $city = &#39;&#39;)
  {
    return &#39;Hello,&#39; . $name . &#39;! You come from &#39; . $city . &#39;.&#39;;
  }
Die Zugriffsadresse ist http:/ /tp5.com/index.php/index/index/hello/name/thinkphp/city/shanghai

Das Ergebnis der Seitenausgabe lautet:

Hallo, thinkphp!

Wie Sie sehen können, erhält die Hello-Methode automatisch den Parameterwert mit demselben Namen in der URL-Adresse wie der Parameterwert der Methode, und die Reihenfolge, in der dieser Parameter übergeben wird, wird durch die Reihenfolge nicht beeinflusst der URL-Parameter ist das Ausgabeergebnis der folgenden URL-Adresse das gleiche wie oben:

http://tp5.com/index.php/index/index/hello/city /shanghai/name/thinkphp

oder verwenden Sie http://tp5.com/index .php/index/index/hello?city=shanghai&name=thinkphp

Sie können die URL-Adresse weiter vereinfachen Die Voraussetzung ist, dass wir die Reihenfolge der Parameter klären müssen. Ändern Sie den Wert des Parameters url_param_type in der Anwendungskonfigurationsdatei:


// 按照参数顺序获取
&#39;url_param_type&#39; => 1,

现在,URL的参数传值方式就变成了严格按照操作方法的变量定义顺序来传值了,也就是说我们必须使用下面的URL地址访问才能正确传入name和city参数到hello方法:http://tp5.com/index.php/index/index/hello/thinkphp/shanghai

页面输出结果为:

Hello,thinkphp! You come from shanghai.

如果改变参数顺序为http://tp5.com/index.php/index/index/hello/shanghai/thinkphp

页面输出结果为:

Hello,shanghai! You come from thinkphp.

显然不是我们预期的结果。

同样,我们试图通过http://tp5.com/index.php/index/index/hello/name/thinkphp/city/shanghai

访问也不会得到正确的结果

[注意]按顺序绑定参数的话,操作方法的参数只能使用URL pathinfo变量,而不能使用get或者post变量

隐藏入口

可以去掉URL地址里面的入口文件index.php,但是需要额外配置WEB服务器的重写规则。

以Apache为例,需要在入口文件的同级添加.htaccess文件(官方默认自带了该文件),内容如下


<IfModule mod_rewrite.c>
Options +FollowSymlinks -Multiviews
RewriteEngine on
RewriteCond %{REQUEST_FILENAME} !-d
RewriteCond %{REQUEST_FILENAME} !-f
RewriteRule ^(.*)$ index.php/$1 [QSA,PT,L]
</IfModule>

如果用的phpstudy,规则如下:


<IfModule mod_rewrite.c> 
Options +FollowSymlinks -Multiviews 
RewriteEngine on 
RewriteCond %{REQUEST_FILENAME} !-d 
RewriteCond %{REQUEST_FILENAME} !-f 
RewriteRule ^(.*)$ index.php [L,E=PATH_INFO:$1] 
</IfModule>

接下来就可以使用下面的URL地址访问了

http://tp5.com/index/index/index
http://tp5.com/index/index/hello

如果使用的apache版本使用上面的方式无法正常隐藏index.php,可以尝试使用下面的方式配置.htaccess文件:


<IfModule mod_rewrite.c>
Options +FollowSymlinks -Multiviews
RewriteEngine on
RewriteCond %{REQUEST_FILENAME} !-d
RewriteCond %{REQUEST_FILENAME} !-f
RewriteRule ^(.*)$ index.php?/$1 [QSA,PT,L]
</IfModule>

如果是Nginx环境的话,可以在Nginx.conf中添加:


location / { // …..省略部分代码
  if (!-e $request_filename) {
    rewrite ^(.*)$ /index.php?s=/$1 last;
    break;
  }
}

定义路由

URL地址里面的index模块怎么才能省略呢,默认的URL地址显得有点长,下面就来说说如何通过路由简化URL访问。

我们在路由定义文件(application/route.php)里面添加一些路由规则,如下:


return [
  // 添加路由规则 路由到 index控制器的hello操作方法
  &#39;hello/:name&#39; => &#39;index/index/hello&#39;,
];

该路由规则表示所有hello开头的并且带参数的访问都会路由到index控制器的hello操作方法。

路由之前的URL访问地址为:http://tp5.com/index/index/hello/name/thinkphp

定义路由后就只能访问下面的URL地址http://tp5.com/hello/thinkphp

[注意]定义路由规则后,原来的URL地址将会失效,变成非法请求。

但这里有一个小问题,如果我们只是访问http://tp5.com/hello

将发生错误

事实上这是由于路由没有正确匹配到,我们修改路由规则如下:


return [
  // 路由参数name为可选
  &#39;hello/[:name]&#39; => &#39;index/hello&#39;,
];

使用[]把路由规则中的变量包起来,就表示该变量为可选,接下来就可以正常访问了http://tp5.com/hello

当name参数没有传入值的时候,hello方法的name参数有默认值World,所以输出的内容为 Hello,World!

除了路由配置文件中定义之外,还可以采用动态定义路由规则的方式定义,例如在路由配置文件(application/route.php)的开头直接添加下面的方法:


use think\Route;
Route::rule(&#39;hello/:name&#39;, &#39;index/hello&#39;);

完成的效果和使用配置方式定义是一样的。

无论是配置方式还是通过Route类的方法定义路由,都统一放到路由配置文件application/route.php文件中

[注意]路由配置不支持在模块配置文件中设置

【完整匹配】

前面定义的路由是只要以hello开头就能进行匹配,如果需要完整匹配,可以使用下面的定义:


return [
  // 路由参数name为可选
  &#39;hello/[:name]$&#39; => &#39;index/hello&#39;,
];

当路由规则以$结尾的时候就表示当前路由规则需要完整匹配。

当我们访问下面的URL地址的时候:

http://tp5.com/hello // 正确匹配
http://tp5.com/hello/thinkphp // 正确匹配
http://tp5.com/hello/thinkphp/val/value // 不会匹配

【闭包定义】

还支持通过定义闭包为某些特殊的场景定义路由规则,例如:


return [
  // 定义闭包
  &#39;hello/[:name]&#39; => function ($name) {
    return &#39;Hello,&#39; . $name . &#39;!&#39;;
  },
];

或者


use think\Route;
Route::rule(&#39;hello/:name&#39;, function ($name) {
  return &#39;Hello,&#39; . $name . &#39;!&#39;;
});

[注意]闭包函数的参数就是路由规则中定义的变量

因此,当访问下面的URL地址:http://tp5.com/hello/thinkphp

会输出

Hello,thinkphp!

【设置URL分隔符】

如果需要改变URL地址中的pathinfo参数分隔符,只需要在应用配置文件(application/config.php)中设置:


// 设置pathinfo分隔符
&#39;pathinfo_depr&#39;     => &#39;-&#39;,

路由规则定义无需做任何改变,我们就可以访问下面的地址:http://tp5.com/hello-thinkphp

【路由参数】

还可以约束路由规则的请求类型或者URL后缀之类的条件,例如:


return [
  // 定义路由的请求类型和后缀
  &#39;hello/[:name]&#39; => [&#39;index/hello&#39;, [&#39;method&#39; => &#39;get&#39;, &#39;ext&#39; => &#39;html&#39;]],
];

上面定义的路由规则限制了必须是get请求,而且后缀必须是html的,所以下面的访问地址:

http://tp5.com/hello // 无效
http://tp5.com/hello.html // 有效
http://tp5.com/hello/thinkphp // 无效
http://tp5.com/hello/thinkphp.html // 有效

【变量规则】

接下来,尝试一些复杂的路由规则定义满足不同的路由变量。在此之前,首先增加一个控制器类如下:


<?php
namespace app\index\controller;
class Blog
{
  public function get($id)
  {
    return &#39;查看id=&#39; . $id . &#39;的内容&#39;;
  }
  public function read($name)
  {
    return &#39;查看name=&#39; . $name . &#39;的内容&#39;;
  }
  public function archive($year, $month)
  {
    return &#39;查看&#39; . $year . &#39;/&#39; . $month . &#39;的归档内容&#39;;
  }
}

添加如下路由规则:


return [
  &#39;blog/:year/:month&#39; => [&#39;blog/archive&#39;, [&#39;method&#39; => &#39;get&#39;], [&#39;year&#39; => &#39;\d{4}&#39;, &#39;month&#39; => &#39;\d{2}&#39;]],
  &#39;blog/:id&#39;     => [&#39;blog/get&#39;, [&#39;method&#39; => &#39;get&#39;], [&#39;id&#39; => &#39;\d+&#39;]],
  &#39;blog/:name&#39;    => [&#39;blog/read&#39;, [&#39;method&#39; => &#39;get&#39;], [&#39;name&#39; => &#39;\w+&#39;]],
];

在上面的路由规则中,我们对变量进行的规则约束,变量规则使用正则表达式进行定义。

我们看下几种URL访问的情况

// 访问id为5的内容
http://tp5.com/blog/5
// 访问name为thinkphp的内容
http://tp5.com/blog/thinkphp
// 访问2015年5月的归档内容
http://tp5.com/blog/2015/05

 【路由分组】

上面的三个路由规则由于都是blog打头,所以我们可以做如下的简化:


return [
  &#39;[blog]&#39; => [
    &#39;:year/:month&#39; => [&#39;blog/archive&#39;, [&#39;method&#39; => &#39;get&#39;], [&#39;year&#39; => &#39;\d{4}&#39;, &#39;month&#39; => &#39;\d{2}&#39;]],  
    &#39;:id&#39;     => [&#39;blog/get&#39;, [&#39;method&#39; => &#39;get&#39;], [&#39;id&#39; => &#39;\d+&#39;]],
    &#39;:name&#39;    => [&#39;blog/read&#39;, [&#39;method&#39; => &#39;get&#39;], [&#39;name&#39; => &#39;\w+&#39;]],
  ],
];

对于这种定义方式,我们称之为路由分组,路由分组一定程度上可以提高路由检测的效率

【复杂路由】

有时候,还需要对URL做一些特殊的定制,例如如果要同时支持下面的访问地址

http://tp5.com/blog/thinkphp
http://tp5.com/blog-2015-05

我们只要稍微改变路由定义规则即可:


return [
  &#39;blog/:id&#39;      => [&#39;blog/get&#39;, [&#39;method&#39; => &#39;get&#39;], [&#39;id&#39; => &#39;\d+&#39;]],
  &#39;blog/:name&#39;     => [&#39;blog/read&#39;, [&#39;method&#39; => &#39;get&#39;], [&#39;name&#39; => &#39;\w+&#39;]],
  &#39;blog-<year>-<month>&#39; => [&#39;blog/archive&#39;, [&#39;method&#39; => &#39;get&#39;], [&#39;year&#39; => &#39;\d{4}&#39;, &#39;month&#39; => &#39;\d{2}&#39;]],
];

对 blog-4620f01c9fab72e23a9b679732106cc4-e43ddfe88b0c33e4d0d4a6906a4e933c 这样的非正常规范,我们需要使用e78ad71b8a45d2a3209df4d26f1fcfa6这样的变量定义方式,而不是 :变量名方式。

简单起见,我们还可以把变量规则统一定义,例如:


return [
  // 全局变量规则定义
  &#39;__pattern__&#39;     => [
    &#39;name&#39; => &#39;\w+&#39;,
    &#39;id&#39;  => &#39;\d+&#39;,
    &#39;year&#39; => &#39;\d{4}&#39;,
    &#39;month&#39; => &#39;\d{2}&#39;,
  ],
  // 路由规则定义
  &#39;blog/:id&#39;      => &#39;blog/get&#39;,
  &#39;blog/:name&#39;     => &#39;blog/read&#39;,
  &#39;blog-<year>-<month>&#39; => &#39;blog/archive&#39;,
];

在__pattern__中定义的变量规则我们称之为全局变量规则,在路由规则里面定义的变量规则我们称之为局部变量规则,如果一个变量同时定义了全局规则和局部规则的话,当前的局部规则会覆盖全局规则的,例如:


return [
  // 全局变量规则
  &#39;__pattern__&#39;     => [
    &#39;name&#39; => &#39;\w+&#39;,
    &#39;id&#39;  => &#39;\d+&#39;,
    &#39;year&#39; => &#39;\d{4}&#39;,
    &#39;month&#39; => &#39;\d{2}&#39;,
  ],

  &#39;blog/:id&#39;      => &#39;blog/get&#39;,
  // 定义了局部变量规则
  &#39;blog/:name&#39;     => [&#39;blog/read&#39;, [&#39;method&#39; => &#39;get&#39;], [&#39;name&#39; => &#39;\w{5,}&#39;]],
  &#39;blog-<year>-<month>&#39; => &#39;blog/archive&#39;,
];

URL生成

定义路由规则之后,可以通过Url类来方便的生成实际的URL地址(路由地址),针对上面的路由规则,我们可以用下面的方式生成URL地址。


// 输出 blog/thinkphp
Url::build(&#39;blog/read&#39;, &#39;name=thinkphp&#39;);
Url::build(&#39;blog/read&#39;, [&#39;name&#39; => &#39;thinkphp&#39;]);
// 输出 blog/5
Url::build(&#39;blog/get&#39;, &#39;id=5&#39;);
Url::build(&#39;blog/get&#39;, [&#39;id&#39; => 5]);
// 输出 blog/2015/05
Url::build(&#39;blog/archive&#39;, &#39;year=2015&month=05&#39;);
Url::build(&#39;blog/archive&#39;, [&#39;year&#39; => &#39;2015&#39;, &#39;month&#39; => &#39;05&#39;]);

[注意]build方法的第一个参数使用路由定义中的完整路由地址

还可以使用系统提供的助手函数url来简化


url(&#39;blog/read&#39;, &#39;name=thinkphp&#39;);
// 等效于
Url::build(&#39;blog/read&#39;, &#39;name=thinkphp&#39;);

通常在模板文件中输出的话,可以使用助手函数,例如:


{:url(&#39;blog/read&#39;, &#39;name=thinkphp&#39;)}

如果我们的路由规则发生调整,生成的URL地址会自动变化

如果你配置了url_html_suffix参数的话,生成的URL地址会带上后缀,例如:


&#39;url_html_suffix&#39;  => &#39;html&#39;,

那么生成的URL地址 类似


blog/thinkphp.html 
blog/2015/05.html

如果你的URL地址全部采用路由方式定义,也可以直接使用路由规则来定义URL生成,例如:


url(&#39;/blog/thinkphp&#39;);
Url::build(&#39;/blog/8&#39;);
Url::build(&#39;/blog/archive/2015/05&#39;);

生成方法的第一个参数一定要和路由定义的路由地址保持一致,如果你的路由地址比较特殊,例如使用闭包定义的话,则需要手动给路由指定标识,例如: 


// 添加hello路由标识
Route::rule([&#39;hello&#39;,&#39;hello/:name&#39;], function($name){
  return &#39;Hello,&#39;.$name;
});
// 根据路由标识快速生成URL
Url::build(&#39;hello&#39;, &#39;name=thinkphp&#39;);
// 或者使用
Url::build(&#39;hello&#39;, [&#39;name&#39; => &#39;thinkphp&#39;]);

相关推荐:

实例分享Thinkphp5行为使用方法

实例讲解thinkphp5 加载静态资源路径与常量的示例

Thinkphp5+PHPExcel实现批量上传表格数据功能_php实例

Das obige ist der detaillierte Inhalt vonDetaillierte Beispiele für URL- und Routing-Funktionen von thinkphp5. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn