mirror of
https://github.com/kamilwylegala/cakephp2-php8.git
synced 2024-11-15 03:18:26 +00:00
url encode nested named parameters in unmatched routes
reference: #2988
and 31033239bd
This commit is contained in:
parent
52f206064d
commit
fa6defea37
2 changed files with 7 additions and 7 deletions
|
@ -945,9 +945,9 @@ class Router {
|
||||||
if (!empty($named)) {
|
if (!empty($named)) {
|
||||||
foreach ($named as $name => $value) {
|
foreach ($named as $name => $value) {
|
||||||
if (is_array($value)) {
|
if (is_array($value)) {
|
||||||
$flattend = Hash::flatten($value, '][');
|
$flattend = Hash::flatten($value, '%5D%5B');
|
||||||
foreach ($flattend as $namedKey => $namedValue) {
|
foreach ($flattend as $namedKey => $namedValue) {
|
||||||
$output .= '/' . $name . "[$namedKey]" . self::$_namedConfig['separator'] . rawurlencode($namedValue);
|
$output .= '/' . $name . "%5B{$namedKey}%5D" . self::$_namedConfig['separator'] . rawurlencode($namedValue);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
$output .= '/' . $name . self::$_namedConfig['separator'] . rawurlencode($value);
|
$output .= '/' . $name . self::$_namedConfig['separator'] . rawurlencode($value);
|
||||||
|
|
|
@ -484,7 +484,7 @@ class RouterTest extends CakeTestCase {
|
||||||
$result = Router::url(array('controller' => 'tests', 'pages' => array(
|
$result = Router::url(array('controller' => 'tests', 'pages' => array(
|
||||||
1, 2, 3
|
1, 2, 3
|
||||||
)));
|
)));
|
||||||
$expected = '/tests/index/pages[0]:1/pages[1]:2/pages[2]:3';
|
$expected = '/tests/index/pages%5B0%5D:1/pages%5B1%5D:2/pages%5B2%5D:3';
|
||||||
$this->assertEquals($expected, $result);
|
$this->assertEquals($expected, $result);
|
||||||
|
|
||||||
$result = Router::url(array('controller' => 'tests',
|
$result = Router::url(array('controller' => 'tests',
|
||||||
|
@ -496,7 +496,7 @@ class RouterTest extends CakeTestCase {
|
||||||
'three'
|
'three'
|
||||||
)
|
)
|
||||||
));
|
));
|
||||||
$expected = '/tests/index/pages[param1][0]:one/pages[param1][1]:two/pages[0]:three';
|
$expected = '/tests/index/pages%5Bparam1%5D%5B0%5D:one/pages%5Bparam1%5D%5B1%5D:two/pages%5B0%5D:three';
|
||||||
$this->assertEquals($expected, $result);
|
$this->assertEquals($expected, $result);
|
||||||
|
|
||||||
$result = Router::url(array('controller' => 'tests',
|
$result = Router::url(array('controller' => 'tests',
|
||||||
|
@ -508,7 +508,7 @@ class RouterTest extends CakeTestCase {
|
||||||
'three'
|
'three'
|
||||||
)
|
)
|
||||||
));
|
));
|
||||||
$expected = '/tests/index/pages[param1][one]:1/pages[param1][two]:2/pages[0]:three';
|
$expected = '/tests/index/pages%5Bparam1%5D%5Bone%5D:1/pages%5Bparam1%5D%5Btwo%5D:2/pages%5B0%5D:three';
|
||||||
$this->assertEquals($expected, $result);
|
$this->assertEquals($expected, $result);
|
||||||
|
|
||||||
$result = Router::url(array('controller' => 'tests',
|
$result = Router::url(array('controller' => 'tests',
|
||||||
|
@ -520,14 +520,14 @@ class RouterTest extends CakeTestCase {
|
||||||
'cool'
|
'cool'
|
||||||
)
|
)
|
||||||
));
|
));
|
||||||
$expected = '/tests/index/super[nested][array]:awesome/super[nested][something]:else/super[0]:cool';
|
$expected = '/tests/index/super%5Bnested%5D%5Barray%5D:awesome/super%5Bnested%5D%5Bsomething%5D:else/super%5B0%5D:cool';
|
||||||
$this->assertEquals($expected, $result);
|
$this->assertEquals($expected, $result);
|
||||||
|
|
||||||
$result = Router::url(array('controller' => 'tests', 'namedParam' => array(
|
$result = Router::url(array('controller' => 'tests', 'namedParam' => array(
|
||||||
'keyed' => 'is an array',
|
'keyed' => 'is an array',
|
||||||
'test'
|
'test'
|
||||||
)));
|
)));
|
||||||
$expected = '/tests/index/namedParam[keyed]:is%20an%20array/namedParam[0]:test';
|
$expected = '/tests/index/namedParam%5Bkeyed%5D:is%20an%20array/namedParam%5B0%5D:test';
|
||||||
$this->assertEquals($expected, $result);
|
$this->assertEquals($expected, $result);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue