Maison >développement back-end >tutoriel php >Comment YII utilise les composants d'URL pour embellir la gestion
Cet article présente principalement comment YII utilise le composant url pour embellir la gestion. Il analyse en détail les fonctions spécifiques et les techniques d'utilisation associées du composant urlManager sous forme d'exemples. Les amis dans le besoin peuvent se référer aux exemples de cet article <.>
Décrit comment YII utilise les composants d'URL pour embellir la gestion. Partagez-le avec tout le monde pour votre référence, les détails sont les suivants :composant urlManager
la documentation officielle de yii explique cela comme suit :urlSuffix Le suffixe d'URL utilisé par cette règle. Par défaut, CurlManger::urlSuffix est utilisé et la valeur est nulle. Par exemple, vous pouvez définir ceci sur .html pour que l'URL ressemble à une page statique.
caseSensitive Qu'il soit sensible à la casse, la valeur par défaut est CUrlManager::caseSensitive, la valeur est nulle.
defaultParams Les paramètres d'obtention par défaut utilisés par cette règle. Lors de l'utilisation de cette règle pour analyser une requête, la valeur de ce paramètre sera injectée dans le paramètre $_GET.
matchValue Lors de la création d'une URL, si les paramètres GET correspondent au sous-modèle correspondant. Par défaut, CurlManager::matchValue est utilisé et la valeur est nulle.
Remarque : définir cette propriété sur true réduira les performances.
Nous utilisons quelques exemples pour expliquer les règles de fonctionnement des URL. Nous supposons que nos règles incluent les trois suivantes :array( 'posts'=>'post/list', 'post/<id:\d+>'=>'post/read', 'post/<year:\d{4}>/<title>'=>'post/read', )Appelez $this->createUrl('post/list') pour générer /index. php /posts. La première règle s'applique. Appelez $this->createUrl('post/read',array('id'=>100)) pour générer /index.php/post/100. La deuxième règle s'applique. Appelez $this->createUrl('post/read',array('year'=>2008,'title'=>'a sample post')) pour générer /index.php/ après /2008/a%20sample%20post. La troisième règle s'applique. Appelez $this->createUrl('post/read') pour générer /index.php/post/read. Veuillez noter qu'aucune règle ne s'applique. En résumé, lorsque vous utilisez createUrl pour générer une URL, les paramètres route et GET transmis à la méthode sont utilisés pour déterminer quelles règles d'URL s'appliquent. Si chaque paramètre de la règle d'association peut être trouvé dans le paramètre GET, il sera transmis à createUrl. Si la règle de routage correspond également au paramètre de route, la règle sera utilisée pour générer l'URL. Si le paramètre GET passé à createUrl est l'une des règles requises ci-dessus, les autres paramètres apparaîtront dans la chaîne de requête. Par exemple, si nous appelons $this->createUrl('post/read',array('id'=>100,'year'=>2008)) , nous obtiendrons /index.php/post/100 ? année = 2008. Pour que ces paramètres supplémentaires apparaissent dans les informations de chemin, nous devons ajouter /* à la règle. Ainsi, avec la règle post/3493f3358a126a26f38915ea72d0923c/*, nous pouvons obtenir l'URL /index.php/post/100/year/2008. Comme nous l'avons mentionné, d'autres utilisations des règles d'URL consistent à analyser les URL de requête. Bien entendu, il s’agit d’un processus inverse de la génération d’URL. Par exemple, lorsque l'utilisateur demande /index.php/post/100, la deuxième règle de l'exemple ci-dessus sera appliquée pour analyser la route post/read et le tableau de paramètres GET('id'=>100) (disponible via $ _OBTENIR).
Astuce : Cette URL est une adresse relative générée par la méthode createurl. Afin d'obtenir une URL absolue, nous pouvons utiliser le préfixe yii : :app()->hostInfo, ou appeler createAbsoluteUrl.
Remarque : Les règles d'URL utilisées réduiront les performances de l'application . En effet, lors de l'analyse de l'URL demandée, [CUrlManager] essaie de la faire correspondre en utilisant chaque règle jusqu'à ce qu'une certaine règle puisse s'appliquer. Par conséquent, les applications de sites Web à fort trafic doivent minimiser les règles d’URL qu’elles utilisent.
test.com/vthot Vous souhaitez générer test.com/vthot/'urlSuffix'=>'/',Pour changer le format de l'URL, nous devons configurer l'élément d'application urlManager afin que createUrl puisse automatiquement passer au nouveau format et application Le programme peut comprendre correctement la nouvelle URL :
'urlManager'=>array( 'urlFormat'=>'path', 'showScriptName'=>false, 'urlSuffix'=>'.html', 'rules'=>array( 'posts'=>'post/list', 'post/<id:\d+>'=>array('post/show','urlSuffix'=>'.html'), 'post/<id:\d+>/<mid:\w+>'=>array('post/view','urlSuffix'=>'.xml'), ), ),Exemple 1Code de règle
'posts'=>'post/list',Code d'action
echo $this->createAbsoluteUrl('post/list');Sortiehttp://localhost/test/index.php/postExemple 2Code de règle
'post/<id:\d+>'=>array('post/show','urlSuffix'=>'.html'),Code d'action
echo $this->createAbsoluteUrl('post/show',array('id'=>998, 'name'=>'123'));Sortiehttp://localhost/test/index.php/post/998.html?name=123Exemple trois Code de règle :
'post/<id:\d+>/<mid:\w+>'=>array('post/view','urlSuffix'=>'.xml'),Code d'action
echo $this->createAbsoluteUrl('post/view',array('id'=>998, 'mid'=>'tody'));Sortie http://localhost /test/index.php/post/998/tody.xmlExemple 4Code de règle
'http://<user:\w+>.vt.com/<_c:(look|seek)>'=>array('<_c>/host','urlSuffix'=>'.me'),Code d'action :
echo $this->createAbsoluteUrl('look/host',array('user'=>'boy','mid'=>'ny-01')); echo ''; echo $this->createAbsoluteUrl('looks/host',array('user'=>'boy','mid'=>'ny-01'));Sortiehttp://boy.vt.com/look.me?mid=ny-01
http://localhost/test/ index.php/looks /host/user/boy/mid/ny-01
public function actionUpdate(){ $id = Yii::app()->request->getQuery('id') ; 经过处理的$_GET['id'] } //$id = Yii::app()->request->getPost('id'); 经过处理的$_POST['id'] //$id = Yii::app()->request->getParam('id'); //CHttpRequest更多
2) fonction publique actionUpdate($id) Cela ne prend pas en charge plusieurs clés primaires. Il vérifiera s'il y a un identifiant dans GET. S'il n'y a pas d'identifiant, l'accès ne sera pas autorisé directement <.>
'sayhello/<name>' => 'post/hello', name是PostController actionHello($name)的参数 'post/<alias:[-a-z]+>' => 'post/view', domain/post/e文小写 其中:前面的alias是PostController actionView($alias)的参数 '(posts|archive)/<order:(DESC|ASC)>' => 'post/index', domain/posts/DESC或domain/posts/ASC '(posts|archive)' => 'post/index', domain/posts或domain/archive 'tos' => array('website/page', 'defaultParams' => array('alias' =>'terms_of_service')),
When the URL is /tos, pass terms_of_service as the alias parameter value.
隐藏 index.php
还有一点,我们可以做进一步清理我们的网址,即在URL中藏匿index.php 入口脚本。这就要求我们配置Web服务器,以及urlManager应用程序元件。
1.add showScriptName=>false
2.add project/.htaccess
RewriteEngine on # if a directory or a file exists, use it directly RewriteCond %{REQUEST_FILENAME} !-f RewriteCond %{REQUEST_FILENAME} !-d # otherwise forward it to index.php RewriteRule . index.php
3.开启rewrite
简单的说,在main.php中简单设置urlManager,然后讲了3条规则,基本都覆盖到了。最后是隐藏index.php,请记住.htaccess位于index.php同级目录 ,而不是protected/目录。其他就简单了。
以上就是本文的全部内容,希望对大家的学习有所帮助,更多相关内容请关注PHP中文网!
相关推荐:
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!