Heim  >  Artikel  >  Backend-Entwicklung  >  Wie YII URL-Komponenten verwendet, um die Verwaltung zu verschönern

Wie YII URL-Komponenten verwendet, um die Verwaltung zu verschönern

不言
不言Original
2018-06-15 14:03:511447Durchsuche

In diesem Artikel wird hauptsächlich die Methode zur Verwendung der URL-Komponente zur Verschönerung der Verwaltung in YII vorgestellt. Er analysiert detailliert die spezifischen Funktionen und die damit verbundenen Verwendungsfähigkeiten der URLManager-Komponente in Form von Beispielen Dieser Artikel

Beschreibt, wie YII URL-Komponenten verwendet, um die Verwaltung zu verschönern. Teilen Sie es als Referenz mit allen. Die Details lauten wie folgt:

URLManager-Komponente

Die offizielle Dokumentation von yii erklärt dies wie folgt:

urlSuffix Das von dieser Regel verwendete URL-Suffix. Standardmäßig wird CurlManger::urlSuffix verwendet und der Wert ist null. Sie können dies beispielsweise auf .html festlegen, damit die URL „wie“ eine statische Seite aussieht.
caseSensitive Ob Groß-/Kleinschreibung beachtet wird, der Standardwert ist CUrlManager::caseSensitive, der Wert ist null.
defaultParams Die von dieser Regel verwendeten Standard-Abrufparameter. Wenn Sie diese Regel zum Parsen einer Anfrage verwenden, wird der Wert dieses Parameters in den Parameter $_GET eingefügt.
matchValue Ob beim Erstellen einer URL die GET-Parameter mit dem entsprechenden Untermuster übereinstimmen. Standardmäßig wird CurlManager::matchValue verwendet und der Wert ist null.

Wenn dieses Attribut falsch ist, bedeutet dies, dass eine entsprechende URL erstellt wird, wenn die Route und der Parametername mit den angegebenen Regeln übereinstimmen.

Wenn dieses Attribut wahr ist, muss der angegebene Parameterwert mit dem entsprechenden Parameter-Untermuster übereinstimmen.

Hinweis: Wenn Sie diese Eigenschaft auf „true“ setzen, verringert sich die Leistung.

Anhand einiger Beispiele erläutern wir die URL-Arbeitsregeln. Wir gehen davon aus, dass unsere Regeln die folgenden drei umfassen:

array(
  'posts'=>'post/list',
  &#39;post/<id:\d+>&#39;=>&#39;post/read&#39;,
  &#39;post/<year:\d{4}>/<title>&#39;=>&#39;post/read&#39;,
)

Call $this->createUrl('post/list') to generic /index.php/ Beiträge. Es gilt die erste Regel.

Rufen Sie $this->createUrl('post/read',array('id'=>100)) auf, um /index.php/post/100 zu generieren. Es gilt die zweite Regel.

Rufen Sie $this->createUrl('post/read',array('year'=>2008,'title'=>'a sample post')) auf, um /index.php/ zu generieren. Beitrag /2008/a%20sample%20post. Es gilt die dritte Regel.

Rufen Sie $this->createUrl('post/read') auf, um /index.php/post/read zu generieren. Bitte beachten Sie, dass keine Regeln gelten.

Zusammenfassend lässt sich sagen, dass bei Verwendung von createUrl zum Generieren einer URL die an die Methode übergebenen Routen- und GET-Parameter verwendet werden, um zu bestimmen, welche URL-Regeln gelten. Wenn jeder Parameter in der Zuordnungsregel im GET-Parameter gefunden werden kann, wird er an createUrl übergeben. Wenn die Routenregel auch mit dem Routenparameter übereinstimmt, wird die Regel zum Generieren der URL verwendet.

Wenn der an createUrl übergebene GET-Parameter eine der oben erforderlichen Regeln ist, werden die anderen Parameter in der Abfragezeichenfolge angezeigt. Wenn wir beispielsweise $this->createUrl('post/read',array('id'=>100,'year'=>2008)) aufrufen, erhalten wir /index.php/post/100 ? Jahr=2008. Damit diese zusätzlichen Parameter als Teil der Pfadinformationen erscheinen, sollten wir /* an die Regel anhängen. Daher können wir mit der Regel post/3493f3358a126a26f38915ea72d0923c/* die URL /index.php/post/100/year/2008 erhalten.

Wie bereits erwähnt, dienen URL-Regeln auch dazu, Anforderungs-URLs zu analysieren. Dies ist natürlich ein umgekehrter Prozess der URL-Generierung. Wenn der Benutzer beispielsweise /index.php/post/100 anfordert, wird die zweite Regel aus dem obigen Beispiel angewendet, um die Route post/read und den GET-Parameter array('id'=>100) (verfügbar über $ _ERHALTEN).

Tipp: Diese URL ist eine relative Adresse, die von der Methode createurl generiert wird. Um eine absolute URL zu erhalten, können wir das Präfix yii: :app()->hostInfo verwenden oder createAbsoluteUrl aufrufen.

Hinweis: Die verwendeten URL-Regeln verringern die Leistung der Anwendung . Dies liegt daran, dass [CUrlManager] beim Parsen der angeforderten URL versucht, diese mit jeder Regel abzugleichen, bis eine bestimmte Regel angewendet werden kann. Daher sollten Website-Anwendungen mit hohem Datenverkehr die von ihnen verwendeten URL-Regeln minimieren.

test.com/vthot möchte test.com/vthot/ generieren

&#39;urlSuffix&#39;=>&#39;/&#39;,

Um das URL-Format zu ändern, sollten wir das URLManager-Anwendungselement so konfigurieren, dass createUrl automatisch auf das neue Format umschalten kann und die Anwendung kann die neue URL richtig verstehen:

&#39;urlManager&#39;=>array(
  &#39;urlFormat&#39;=>&#39;path&#39;,
  &#39;showScriptName&#39;=>false,
  &#39;urlSuffix&#39;=>&#39;.html&#39;,
  &#39;rules&#39;=>array(
    &#39;posts&#39;=>&#39;post/list&#39;,
    &#39;post/<id:\d+>&#39;=>array(&#39;post/show&#39;,&#39;urlSuffix&#39;=>&#39;.html&#39;),
    &#39;post/<id:\d+>/<mid:\w+>&#39;=>array(&#39;post/view&#39;,&#39;urlSuffix&#39;=>&#39;.xml&#39;),
  ),
),

Beispiel 1

Regelcode

&#39;posts&#39;=>&#39;post/list&#39;,

Aktionscode

echo $this->createAbsoluteUrl(&#39;post/list&#39;);

Ausgabe

http://localhost/test/index.php/post

Beispiel 2

Regelcode

&#39;post/<id:\d+>&#39;=>array(&#39;post/show&#39;,&#39;urlSuffix&#39;=>&#39;.html&#39;),

Aktionscode

echo $this->createAbsoluteUrl(&#39;post/show&#39;,array(&#39;id&#39;=>998, &#39;name&#39;=>&#39;123&#39;));

Ausgabe

http://localhost/test/index.php/post/998.html?name=123

Beispiel 3

Regel Code:

&#39;post/<id:\d+>/<mid:\w+>&#39;=>array(&#39;post/view&#39;,&#39;urlSuffix&#39;=>&#39;.xml&#39;),

Aktionscode

echo $this->createAbsoluteUrl(&#39;post/view&#39;,array(&#39;id&#39;=>998, &#39;mid&#39;=>&#39;tody&#39;));

Ausgabe

http://localhost/test/index.php/post/998/tody.xml

Beispiel vier

Regelcode

&#39;http://<user:\w+>.vt.com/<_c:(look|seek)>&#39;=>array(&#39;<_c>/host&#39;,&#39;urlSuffix&#39;=>&#39;.me&#39;),

Aktionscode:

echo $this->createAbsoluteUrl(&#39;look/host&#39;,array(&#39;user&#39;=>&#39;boy&#39;,&#39;mid&#39;=>&#39;ny-01&#39;));
echo &#39;&#39;;
echo $this->createAbsoluteUrl(&#39;looks/host&#39;,array(&#39;user&#39;=>&#39;boy&#39;,&#39;mid&#39;=>&#39;ny-01&#39;));

Ausgabe

http ://boy .vt.com/look.me?mid=ny-01
http://localhost/test/index.php/looks/host/user/boy/mid/ny-01

1) controller/Update/id/23

public function actionUpdate(){
  $id = Yii::app()->request->getQuery(&#39;id&#39;) ; 经过处理的$_GET[&#39;id&#39;]
}
//$id = Yii::app()->request->getPost(&#39;id&#39;); 经过处理的$_POST[&#39;id&#39;]
//$id = Yii::app()->request->getParam(&#39;id&#39;); //CHttpRequest更多

2) öffentliche Funktion actionUpdate($id) Dies unterstützt nicht mehrere Primärschlüssel. Es wird überprüft Unabhängig davon, ob eine ID in GET vorhanden ist, ist der Zugriff ohne ID nicht zulässig

&#39;sayhello/<name>&#39; => &#39;post/hello&#39;, name是PostController actionHello($name)的参数
&#39;post/<alias:[-a-z]+>&#39; => &#39;post/view&#39;,  domain/post/e文小写 其中:前面的alias是PostController actionView($alias)的参数
&#39;(posts|archive)/<order:(DESC|ASC)>&#39; => &#39;post/index&#39;, domain/posts/DESC或domain/posts/ASC
&#39;(posts|archive)&#39; => &#39;post/index&#39;, domain/posts或domain/archive
&#39;tos&#39; => array(&#39;website/page&#39;, &#39;defaultParams&#39; => array(&#39;alias&#39; =>&#39;terms_of_service&#39;)),

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中文网!

相关推荐:

关于Yii基于数组和对象的Model查询

Yii和CKEditor实现图片上传的功能

Yii2如何使用Bootbox插件实现自定义弹窗

Das obige ist der detaillierte Inhalt vonWie YII URL-Komponenten verwendet, um die Verwaltung zu verschönern. 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