/index.php/user/register //正しいリンク
最初のリンクは間違っています。ブラウザは 404 エラーを返します。 2 番目のリンクは、UserController の Register メソッドにアクセスします。違いは、2 番目のリンクが生成されるときに渡すパラメーターが配列であるのに対し、最初のメソッドは単純な文字列であることです。 Yii が URL を処理するとき、単純な文字列に遭遇すると、その文字列を最終的な URL として直接使用します。
単純な文字列と言えば、これら 2 つのリンクがあります。実はこれは非常に本質的な違いなのです。これらも文字列「user/register」ですが、最初の文字列は 13 文字の相対パスを表し、2 番目のリンクは特別な意味を持つ UserController の registerAction を表します。
Yii の URL 処理メソッド NormalizeUrl のソース コードを添付します:
コードをコピーします コードは次のとおりです:
/**
* 入力パラメータを有効な URL になるように正規化します。
*
* 入力パラメータが空の文字列の場合、現在リクエストされている URL が返されます。
*
* 入力パラメータが空ではない文字列の場合、有効な URL として扱われ、変更せずに
* が返されます。
*
* 入力パラメータが配列の場合、コントローラ ルートおよび
* GET パラメータのリストとして扱われ、
* URL を作成するために {@link CController::createUrl} メソッドが呼び出されます。この場合、最初の配列要素はコントローラー ルート
* を参照し、残りのキーと値のペアは URL の追加の GET パラメーターを参照します。
* 例: array('post/list', 'page'=>3)
URL
* /index.php?r=post/list&page=3
を生成するために使用できます。
*
* @parammixed $url 有効な URL を生成するために使用されるパラメータ
* @return string 正規化された URL
*/
public static functionnormalizeUrl($url)
{
if(is_array ($url))
{
if(isset($url[0]))
{
if(($c=Yii::app()->getController())!==null)
$url= $c->createUrl($url[0],array_splice($url,1));
else
$url=Yii::app()->createUrl($url[0],array_splice) ($url, 1));
}
$url='';
}
return $url=='' ? $url;
}
http://www.bkjia.com/PHPjc/324933.html
www.bkjia.com本当http://www.bkjia.com/PHPjc/324933.html技術記事次のようにコードをコピーします。 ?php echo CHtml::link('wrong link','user/register')? ?php echo CHtml::link('correct link',array('user/register'))? URLManager の構成は次のように決定されます...