プロジェクト

全般

プロフィール

Backport(バックポート) #3330

完了

opJsonApiActions 内で Content-Type の設定が2度呼び出されている

Chiharu Nakajima さんが11年以上前に追加. 11年以上前に更新.

ステータス:
Fixed(完了)
優先度:
Normal(通常)
担当者:
対象バージョン:
開始日:
2013-04-15
期日:
進捗率:

100%

予定工数:

説明

Overview (現象)

opJsonApiActions クラス内で $this->getResponse()->setContentType('application/json') が execute() メソッドと renderJSON() メソッドで 2 度呼び出されている。また、これによって各 API のアクション内で Content-Type の設定を上書きすることが出来ない。

(現象補足)
apiを使用しているプラグインでは、使用しているjavascriptライブラリとの都合上、content-typeが「text/html」である必要があるものがあります。
(デフォルトでライブラリの中でstringをjsonオブジェクトに変換します。)
そのため、actionsのexecuteXxx()内でcontent-typeの書き換えを行っています。
その変更をopJsonApiActionsのrenderJSON()で「application/json」に再度置き換えられるために不具合発生となります。

Way to fix (修正内容)

opJsonApiActions::renderJSON() メソッド内の setContentType の呼び出しが不要なため除去する。


関連するチケット 1 (0件未完了1件完了)

関連している OpenPNE 3 - Bug(バグ) #3198: opJsonApiActions 内で Content-Type の設定が2度呼び出されているWon't fix(対応せず)Youichi Kimura2012-09-11

操作

kaoru n さんが11年以上前に更新

  • ステータスNew(新規) から Accepted(着手) に変更
  • 担当者kaoru n にセット

kaoru n さんが11年以上前に更新

  • ステータスAccepted(着手) から Pending Review(レビュー待ち) に変更
  • 進捗率0 から 50 に変更

https://github.com/openpne/OpenPNE3/pull/77
プルリクエストしました。

Yuya Watanabe さんが11年以上前に更新

下記と同じ理由でマージはまだしていません.

https://redmine.openpne.jp/issues/3198#note-6

kaoru n さんが11年以上前に更新

原因について

https://redmine.openpne.jp/issues/3198#note-6
のとおりですが、少しだけ補足します。

apiを使用しているプラグインでは、使用しているjavascriptライブラリとの都合上、content-typeが「text/html」である必要があるものがあります。
(デフォルトでライブラリの中でstringをjsonオブジェクトに変換します。)
そのため、actionsのexecuteXxx()内でcontent-typeの書き換えを行っています。
その変更をopJsonApiActionsのrenderJSON()で「application/json」に再度置き換えられるために不具合発生となります。

上記についてチケット本文にも記載を行いました。

kaoru n さんが11年以上前に更新

Yuya Watanabe さんが11年以上前に更新

  • ステータスPending Review(レビュー待ち) から Pending Testing(テスト待ち) に変更
  • 進捗率50 から 70 に変更

Yuya Watanabe さんが11年以上前に更新

  • ステータスPending Testing(テスト待ち) から Pending Review(レビュー待ち) に変更
  • 進捗率70 から 50 に変更

更新履歴 8579ec654a1df2c5df6683c13c43b6a895f4a5d8 で適用されました。

Yuya Watanabe さんが11年以上前に更新

  • ステータスPending Review(レビュー待ち) から Pending Testing(テスト待ち) に変更
  • 進捗率50 から 70 に変更

ステータスが戻っていたのでテスト待ちに戻します

Chiharu Nakajima さんが11年以上前に更新

  • ステータスPending Testing(テスト待ち) から Fixed(完了) に変更
  • 進捗率70 から 100 に変更

確認しました。問題ありません。
チケットをクローズします。

他の形式にエクスポート: Atom PDF