Cet article présente principalement la configuration du composant urlManager de Yii, qui a une certaine valeur de référence. Maintenant, je le partage avec tout le monde. Les amis dans le besoin peuvent s'y référer.
Les composants de configuration incluent principalement : <.>
doit spécifier la classe pour le composant. S'il n'est pas spécifié, une erreur sera signalée, sauf si le composant a une classe par défaut. avez-vous des classes par défaut ? C'est le composant principal. Installez B et regardez le code source. Prenons l'exemple du modèle avancé yii.
Pis : Sauf indication contraire, le chemin ci-dessous fait référence au chemin spécifique du fichier, et non à l'espace de noms
et voir Pour /frontend/web/index.php
utilisez d'abord la méthode de fusion de la
classe d'assistance de tableau pour fusionner les tableaux de manière récursive, puis écrasez le précédent pour obtenir la configuration finale. transmettez les données de configuration à Dans le constructeur de , exécutez sa méthode run. Application
, il a été constaté que la méthode coreComponents était exécutée et que son contenu était verdoryiisoftyiiConfiguration du composant urlManager de YiiwebApplication.php
components
La classe par défaut d'urlManager n'a pas été trouvée et chaque fichier de configuration ne spécifiait pas de classe pour urlManager. . Pourquoi aucune erreur n’a-t-elle été signalée ? Parce qu'il appelle la méthode de la classe parent. coreComponents
verdoryiisoftyiiConfiguration du composant urlManager de YiibaseApplication.php
Nous savons déjà que la classe du composant principal est spécifiée via
, le constructeur est automatiquement appelé ! Nous avons constaté que coreComponents
n'a pas remplacé le constructeur de la classe parent, c'est-à-dire regardez le constructeur de la classe parent Application
省略~webApplication
Focus sur preInit
$config
ce qui signifie probablement, <.>Si le fichier de configuration ne configure pas un certain composant ou ne spécifie pas de classe pour un composant, ce composant utilise la classe
. Après avoir construit la variable , transmettez-la à coreComponents
pour démarrer le contenu spécifique du composant et ne pas aller plus loin. $config
Component::__construct($config)
. /项目目录/frontend/config/main.php
urlManager
vendoryiisoftyiiConfiguration du composant urlManager de YiiwbeUrlManager.php
Pour résumer : configuration du composant, précisez d'abord la classe (s'il n'y a pas de défaut, il faut l'indiquer dans le fichier de configuration), deuxième attribut de configuration, l'attribut est le variable membre de la classe
Configuration du composant urlManager de Yii Ajouter un hôte virtuel
<VirtualHost *:Configuration du composant urlManager de Yii0>DocumentRoot "${INSTALL_DIR}/www/advanced/frontend/web/"ServerName frontend.advanced.com</VirtualHost>
effectue l'action3 Chaque fonction de configuration
Site
about
enablePrettyUrl
Pis : définissez ceci sur false, les paramètres suivants ne fonctionneront pas
http://localhost/advanced/frontend/web/index.php?r=site/about
http://localhost/advanced/frontend/web/index.php/site/about
terminé que vous pourrez accéder à showScriptName
via
true [默认]: 不隐藏入口脚本,即要加入口脚本文件名index.php才能访问到,http://localhost/advanced/frontend/web/index.php/site/about
false:按理解,设为false,应该是http://localhost/advanced/frontend/web/site/about
即可访问,但发现是apache提示找不到页面,
这意味着,apache服务器找不到url请求的文件,按apache理解,省略~/web/
下没有site
目录,所以,想要实现隐藏入口脚本,还要在/frontend/web/
下添加.htaccess
文件,官方文档介绍,具体步骤如下:
RewriteEngine onRewriteCond %{REQUEST_FILENAME} !-fRewriteCond %{REQUEST_FILENAME} !-dRewriteRule . index.php
在.htaccess
添加内容如下,意思是,如果请求的文件或目录找不到,就转到index.php
enableStrictParsing
:
false [默认]:不启用严格解析路由,意思是,如果请求url与所有rules
规则都不匹配的话,就按照默认的路由处理方式来处理,即按[模块/]控制器/动作,方式去解析url。
true:设为true后,当请求url与rules
规则不匹配,就报错。
如,通过http://frontend.advanced.com/site/about
请求,得到Yii框架的报错提示
这意味着,请求经过apache的转发,已经找到目的文件(入口脚本),目的文件运行过程中,没有得到期望参数(没传或验证不通过),因此Yii框架抛异常了。
注意与上面apache提示找不到页面区分~
suffix
: 后缀名,如设置为suffix => '.html
,需通过http://frontend.advanced.com/site/about.html
才能访问到
rules
: 规则的配置就很复杂了,下面详讲。
rules
配置想访问Site
的about
动作,要在rules里加
'site/about' => 'site/about'
其中,左边称为pattern
,对应输入的url,右边为route
,对应[模型/]控制器/动作。
如果不想为每个动作都加一个规则,可以这样
'<controller:\w+>/<action:\w+>' => '<controller>/<action>',
可以这样理解,左边,接收请求url的对应值,对它们作\w
验证,即必须是字母或数字或下划线,以/site/about
为例,验证通过,赋值给临时变量controller
,action
,右边使用,从而找到Site
控制器的about
动作。
同理,模块下的控制器动作也可以这样实现
'<module:\w+>/<controller:\w+>/<action:\w+>' => '<module>/<controller>/<action>',
restful的路由规则,在研究,日后再补~
suffix
设了.html
, 下面的rules都会用到,要想不用,需要在规则数组单独声明suffix=> ''
restful路由配置,pluralize
参数默认为true,假如控制器为UserController
,要通过users
的url才能访问到,设为false的话,就不用加s,通过user
即可访问,如果控制器本来就是UsersController
,不管pluralize
如何配置,都是通过users
访问
相关推荐:
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!