|
|
@ -24,6 +24,10 @@ class Controller extends \yii\base\Controller |
|
|
|
* CSRF validation is enabled only when both this property and [[Request::enableCsrfValidation]] are true. |
|
|
|
* CSRF validation is enabled only when both this property and [[Request::enableCsrfValidation]] are true. |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
public $enableCsrfValidation = true; |
|
|
|
public $enableCsrfValidation = true; |
|
|
|
|
|
|
|
/** |
|
|
|
|
|
|
|
* @var array the parameters bound to the current action. This is mainly used by [[getCanonicalUrl()]]. |
|
|
|
|
|
|
|
*/ |
|
|
|
|
|
|
|
public $actionParams = []; |
|
|
|
|
|
|
|
|
|
|
|
/** |
|
|
|
/** |
|
|
|
* Binds the parameters to the action. |
|
|
|
* Binds the parameters to the action. |
|
|
@ -46,13 +50,14 @@ class Controller extends \yii\base\Controller |
|
|
|
|
|
|
|
|
|
|
|
$args = []; |
|
|
|
$args = []; |
|
|
|
$missing = []; |
|
|
|
$missing = []; |
|
|
|
|
|
|
|
$actionParams = []; |
|
|
|
foreach ($method->getParameters() as $param) { |
|
|
|
foreach ($method->getParameters() as $param) { |
|
|
|
$name = $param->getName(); |
|
|
|
$name = $param->getName(); |
|
|
|
if (array_key_exists($name, $params)) { |
|
|
|
if (array_key_exists($name, $params)) { |
|
|
|
$args[] = $params[$name]; |
|
|
|
$args[] = $actionParams[$name] = $params[$name]; |
|
|
|
unset($params[$name]); |
|
|
|
unset($params[$name]); |
|
|
|
} elseif ($param->isDefaultValueAvailable()) { |
|
|
|
} elseif ($param->isDefaultValueAvailable()) { |
|
|
|
$args[] = $param->getDefaultValue(); |
|
|
|
$args[] = $actionParams[$name] = $param->getDefaultValue(); |
|
|
|
} else { |
|
|
|
} else { |
|
|
|
$missing[] = $name; |
|
|
|
$missing[] = $name; |
|
|
|
} |
|
|
|
} |
|
|
@ -64,6 +69,8 @@ class Controller extends \yii\base\Controller |
|
|
|
])); |
|
|
|
])); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
$this->actionParams = $actionParams; |
|
|
|
|
|
|
|
|
|
|
|
return $args; |
|
|
|
return $args; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
@ -113,6 +120,22 @@ class Controller extends \yii\base\Controller |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
/** |
|
|
|
/** |
|
|
|
|
|
|
|
* Returns the canonical URL of the currently requested page. |
|
|
|
|
|
|
|
* The canonical URL is constructed using [[route]] and [[actionParams]]. You may use the following code |
|
|
|
|
|
|
|
* in the layout view to add a link tag about canonical URL: |
|
|
|
|
|
|
|
* |
|
|
|
|
|
|
|
* ~~~ |
|
|
|
|
|
|
|
* $this->registerLinkTag(['rel' => 'canonical', 'href' => Yii::$app->controller->canonicalUrl]); |
|
|
|
|
|
|
|
* ~~~ |
|
|
|
|
|
|
|
* |
|
|
|
|
|
|
|
* @return string |
|
|
|
|
|
|
|
*/ |
|
|
|
|
|
|
|
public function getCanonicalUrl() |
|
|
|
|
|
|
|
{ |
|
|
|
|
|
|
|
return Yii::$app->getUrlManager()->createAbsoluteUrl($this->getRoute(), $this->actionParams); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/** |
|
|
|
* Redirects the browser to the specified URL. |
|
|
|
* Redirects the browser to the specified URL. |
|
|
|
* This method is a shortcut to [[Response::redirect()]]. |
|
|
|
* This method is a shortcut to [[Response::redirect()]]. |
|
|
|
* |
|
|
|
* |
|
|
|