Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
Y
yii2
Project
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
PSDI Army
yii2
Commits
1cd05b46
Commit
1cd05b46
authored
Sep 28, 2014
by
Qiang Xue
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
finished routing tutoail [skip ci]
parent
c31da68d
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
87 additions
and
3 deletions
+87
-3
runtime-routing.md
docs/guide/runtime-routing.md
+83
-0
translation-status.md
docs/internals/translation-status.md
+4
-3
No files found.
docs/guide/runtime-routing.md
0 → 100644
View file @
1cd05b46
Routing
=======
When the
[
[yii\web\Application::run()|run()
]
] method is called by the
[
entry script
](
structure-entry-scripts.md
)
,
the first thing it does is to resolve the incoming request and instantiate an appropriate
[
controller action
](
structure-controllers.md
)
to handle the request. This process is called
*routing*
.
## Resolving Route <a name="resolving-route"></a>
The first step of routing is to parse the incoming request into a route which, as described in
the
[
Controllers
](
structure-controllers.md#routes
)
section, is used to address a controller action.
This is done by
[
[yii\web\Request::resolve()|resolve()
]
] method of the
`request`
application component.
The method invokes the
[
URL manager
](
runtime-url-handling.md
)
to do the actual request parsing work.
By default, if the incoming request contains a
`GET`
parameter named
`r`
, its value will be considered
as the route. However, if the
[
[yii\web\UrlManager::enablePrettyUrl|pretty URL feature
]
] is enabled,
more work will be done to determine the requested route. For more details, please refer to
the
[
URL Parsing and Generation
](
runtime-url-handling.md
)
section.
In case a route cannot be determined, the
`request`
component will throw a
[
[yii\web\NotFoundHttpException
]
].
### Default Route <a name="default-route"></a>
If an incoming request does not specify a route, which often happens to the request for homepages,
the route specified by
[
[yii\web\Application::defaultRoute
]
] will be used. The default value of this property
is
`site/index`
, which refers to the
`index`
action of the
`site`
controller. You may customize this property
in the application configuration like the following:
```
php
return
[
// ...
'defaultRoute'
=>
'main/index'
,
];
```
### `catchAll` Route <a name="catchall-route"></a>
Sometimes, you may want to put your Web application in maintenance mode temporarily and display the same
informational page for all requests. There are many ways to accomplish this goal. But one of the simplest
ways is to configure the
[
[yii\web\Application::catchAll
]
] property like the following in the application configuration:
```
php
return
[
// ...
'catchAll'
=>
[
'site/offline'
],
];
```
The
`catchAll`
property should take an array whose first element specifies a route, and
the rest of the elements (name-value pairs) specify the parameters to be bound to the action.
When the
`catchAll`
property is set, it will replace any route resolved from the incoming requests.
With the above configuration, the same
`site/offline`
action will be used to handle all incoming requests.
## Creating Action <a name="creating-action"></a>
Once the requested route is determined, the next step is to create the action object corresponding to the route.
The route is broken down into multiple parts by the slashes in it. For example,
`site/index`
will be
broken into
`site`
and
`index`
. Each part is an ID which may refer to a module, a controller or an action.
Starting from the first part in the route, the application conducts the following steps to create modules (if any),
the controller and the action:
1.
Set the application as the current module.
2.
Check if the
[
[yii\base\Module::controllerMap|controller map
]
] of the current module contains the current ID.
If so, a controller object will be created according to the controller configuration found in the map,
and do Step 5 with the rest parts of the route.
3.
Check if the ID refers to a module listed in the
[
[yii\base\Module::modules|modules
]
] property of
the current module. If so, a module is created according to the configuration found in the module list,
and do Step 2 with the next part in the route under the context of the newly created module.
4.
Treat the ID as a controller ID and create a controller object. Do the next step with the rest part of
the route.
5.
The controller looks for the current ID in its
[
[yii\base\Controller::actions()|action map
]
]. If found,
it creates an action according to the configuration found in the map. Otherwise, the controller will
attempt to create an inline action which is defined by an action method corresponding to the current ID.
Among the above steps, if any error occurs, a
[
[yii\web\NotFoundHttpException
]
] will be thrown, indicating
failure of the routing.
docs/internals/translation-status.md
View file @
1cd05b46
...
...
@@ -23,10 +23,11 @@ structure-models.md | Yes
structure-modules.md | Yes
structure-filters.md | Yes
structure-widgets.md | Yes
structure-assets.md |
structure-assets.md |
Yes
structure-extensions.md | Yes
runtime-bootstrapping.md |
runtime-routing.md |
runtime-overview.md | Yes
runtime-bootstrapping.md | Yes
runtime-routing.md | Yes
runtime-requests.md |
runtime-responses.md |
runtime-sessions-cookies.md |
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment