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
b95798d0
Commit
b95798d0
authored
Nov 21, 2014
by
Nobuo Kihara
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
docs/guide-ja/runtime-responses.md - WIP [ci skip]
parent
9f09bb76
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
36 additions
and
34 deletions
+36
-34
runtime-responses.md
docs/guide-ja/runtime-responses.md
+36
-34
No files found.
docs/guide-ja/runtime-responses.md
View file @
b95798d0
...
@@ -56,40 +56,41 @@ throw new \yii\web\HttpException(402);
...
@@ -56,40 +56,41 @@ throw new \yii\web\HttpException(402);
## HTTP ヘッダ <a name="http-headers"></a>
## HTTP ヘッダ <a name="http-headers"></a>
You can send HTTP headers by manipulating the
[
[yii\web\Response::headers|header collection
]
] in the
`response`
component.
`response`
コンポーネントの
[
[yii\web\Response::headers|ヘッダコレクション
]
] を操作することによって、
For example,
HTTP ヘッダを送信することが出来ます。例えば、
```
php
```
php
$headers
=
Yii
::
$app
->
response
->
headers
;
$headers
=
Yii
::
$app
->
response
->
headers
;
//
add a Pragma header. Existing Pragma headers will NOT be overwritten.
//
Pragma ヘッダを追加する。既存の Pragma ヘッダは上書きされない。
$headers
->
add
(
'Pragma'
,
'no-cache'
);
$headers
->
add
(
'Pragma'
,
'no-cache'
);
//
set a Pragma header. Any existing Pragma headers will be discarded.
//
Pragma ヘッダを設定する。既存の Pragma ヘッダは全て破棄される。
$headers
->
set
(
'Pragma'
,
'no-cache'
);
$headers
->
set
(
'Pragma'
,
'no-cache'
);
//
remove Pragma header(s) and return the removed Pragma header values in an array
//
Pragma ヘッダを削除して、削除された Pragma ヘッダの値を配列に返す。
$values
=
$headers
->
remove
(
'Pragma'
);
$values
=
$headers
->
remove
(
'Pragma'
);
```
```
> Info
: Header names are case insensitive. And the newly registered headers are not sent to the user until
> Info
|情報: ヘッダ名は大文字小文字を区別しません。そして、新しく登録されたヘッダは、
the
[
[yii\web\Response::send()
]
] method is called.
[
[yii\web\Response::send()
]
] メソッドが呼ばれるまで送信されません。
##
Response Body
<a name="response-body"></a>
##
レスポンスボディ
<a name="response-body"></a>
Most responses should have a body which gives the content that you want to show to end users.
ほとんどのレスポンスは、エンドユーザに対して表示したい内容を示すボディを持っていなければなりません。
If you already have a formatted body string, you may assign it to the
[
[yii\web\Response::content
]
] property
既にフォーマットされたボディの文字列を持っている場合は、それをレスポンスの
[
[yii\web\Response::content
]
]
of the response. For example,
プロパティに割り付けることが出来ます。例えば、
```
php
```
php
Yii
::
$app
->
response
->
content
=
'hello world!'
;
Yii
::
$app
->
response
->
content
=
'hello world!'
;
```
```
If your data needs to be formatted before sending it to end users, you should set both of the
データをエンドユーザに送信する前にフォーマットする必要がある場合は、
[
[yii\web\Response::format|format
]
] と
[
[yii\web\Response::data|data
]
]
[
[yii\web\Response::format|format
]
] and
[
[yii\web\Response::data|data
]
] properties. The
[
[yii\web\Response::format|format
]
]
の両方のプロパティをセットしなければなりません。
[
[yii\web\Response::format|format
]
]
property specifies in which format the
[
[yii\web\Response::data|data
]
] should be formatted. For example,
プロパティは
[
[yii\web\Response::data|data
]
] がどの形式でフォーマットされるべきかを指定するものです。
例えば、
```
php
```
php
$response
=
Yii
::
$app
->
response
;
$response
=
Yii
::
$app
->
response
;
...
@@ -97,18 +98,19 @@ $response->format = \yii\web\Response::FORMAT_JSON;
...
@@ -97,18 +98,19 @@ $response->format = \yii\web\Response::FORMAT_JSON;
$response
->
data
=
[
'message'
=>
'hello world'
];
$response
->
data
=
[
'message'
=>
'hello world'
];
```
```
Yii supports the following formats out of the box, each implemented by a
[
[yii\web\ResponseFormatterInterface|formatter
]
] class.
Yii は下記の形式を初めからサポートしています。それぞれ、
[
[yii\web\ResponseFormatterInterface|フォーマッタ
]
] クラスとして実装されています。
You can customize these formatters or add new ones by configuring the
[
[yii\web\Response::formatters
]
] property.
[
[yii\web\Response::formatters
]
] プロパティを構成することで、これらのフォーマッタをカスタマイズしたり、
または、新しいフォーマッタを追加することが出来ます。
*
[
[yii\web\Response::FORMAT_HTML|HTML
]
]: implemented by
[
[yii\web\HtmlResponseFormatter
]
].
*
[
[yii\web\Response::FORMAT_HTML|HTML
]
]:
[
[yii\web\HtmlResponseFormatter
]
] によって実装
*
[
[yii\web\Response::FORMAT_XML|XML
]
]: implemented by
[
[yii\web\XmlResponseFormatter
]
].
*
[
[yii\web\Response::FORMAT_XML|XML
]
]:
[
[yii\web\XmlResponseFormatter
]
] によって実装
*
[
[yii\web\Response::FORMAT_JSON|JSON
]
]: implemented by
[
[yii\web\JsonResponseFormatter
]
].
*
[
[yii\web\Response::FORMAT_JSON|JSON
]
]:
[
[yii\web\JsonResponseFormatter
]
] によって実装
*
[
[yii\web\Response::FORMAT_JSONP|JSONP
]
]: implemented by
[
[yii\web\JsonResponseFormatter
]
].
*
[
[yii\web\Response::FORMAT_JSONP|JSONP
]
]:
[
[yii\web\JsonResponseFormatter
]
] によって実装
*
[
[yii\web\Response::FORMAT_RAW|RAW
]
]: use this format if you want to send the response directly without applying any formatting.
*
[
[yii\web\Response::FORMAT_RAW|RAW
]
]: 書式を何も適用せずにレスポンスを送信したいときは、このフォーマットを使用
レスポンスボディは、上記のように、明示的に設定することも出来ますが、たいていの場合は、
[
アクション
](
structure-controllers.md
)
メソッドの返り値によって暗黙のうちに設定することが出来ます。よくあるユースケースは下記のようなものになります。
While the response body can be set explicitly as shown above, in most cases you may set it implicitly by the return value
of
[
action
](
structure-controllers.md
)
methods. A common use case is like the following:
```
php
```
php
public
function
actionIndex
()
public
function
actionIndex
()
{
{
...
@@ -116,12 +118,11 @@ public function actionIndex()
...
@@ -116,12 +118,11 @@ public function actionIndex()
}
}
```
```
The
`index`
action above returns the rendering result of the
`index`
view. The return value will be taken
上記の
`index`
アクションは、
`index`
ビューのレンダリング結果を返しています。返された値は
`response`
by the
`response`
component, formatted and then sent to end users.
コンポーネントによって受け取られ、フォーマットされてエンドユーザに送信されます。
Because by default the response format is
[
[yii\web\Response::FORMAT_HTML|HTML
]
], you should only return a string
デフォルトのレスポンス形式が
[
[yii\web\Response::FORMAT_HTML|HTML
]
] であるため、アクションメソッドの中では文字列を返すだけにすべきです。
in an action method. If you want to use a different response format, you should set it first before returning the data.
別のレスポンス形式を使いたい場合は、データを返す前にレスポンス形式を設定しなければなりません。例えば、
For example,
```
php
```
php
public
function
actionInfo
()
public
function
actionInfo
()
...
@@ -134,8 +135,9 @@ public function actionInfo()
...
@@ -134,8 +135,9 @@ public function actionInfo()
}
}
```
```
As aforementioned, besides using the default
`response`
application component, you can also create your own
既に述べたように、デフォルトの
`response`
アプリケーションコンポーネントを使う代りに、
response objects and send them to end users. You can do so by returning such object in an action method, like the following,
自分自身のレスポンスオブジェクトを作成してエンドユーザに送信することも出来ます。そうするためには、次のように、
アクションメソッドの中でそのようなオブジェクトを返します。
```
php
```
php
public
function
actionInfo
()
public
function
actionInfo
()
...
@@ -151,9 +153,9 @@ public function actionInfo()
...
@@ -151,9 +153,9 @@ public function actionInfo()
}
}
```
```
> Note
: If you are creating your own response objects, you will not be able to take advantage of the configurations
> Note
|注意: 自分自身のレスポンスオブジェクトを作成しようとする場合は、アプリケーションのコンフィギュレーションで `response`
that you set for the
`response`
component in the application configuration. You can, however, use
コンポーネントのために設定したコンフィギュレーションを利用することは出来ません。しかしながら、
[
依存の注入
](
concept-di-container.md
)
を使って、
[
dependency injection
](
concept-di-container.md
)
to apply a common configuration to your new response objects.
共通のコンフィギュレーションをあなたの新しいレスポンスオブジェクトに適用することは出来ます。
## Browser Redirection <a name="browser-redirection"></a>
## Browser Redirection <a name="browser-redirection"></a>
...
...
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