buddypressの表示される時間が9時間遅れる

解決済

回答 2

投稿 編集

  • 評価
  • クリップ 1
  • VIEW 1,160

発生している問題

wordpressプラグイン「buddypress」を利用してテーマ作成をしています。
buddypressの関数で表示される時間がすべて9時間遅れます。
date_default_timezone_get()では「Asia/Tokyo」と出力されるためwordpressのタイムゾーンに誤りはないです。
以下をbp-custom.phpに設置したりもしてみましたが、解決しませんでした。

date_default_timezone_set('asia/tokyo');

 環境

wordpress バージョン 4.5.2
buddypress バージョン 2.6.0

管理画面のタイムゾーンの現状です。撮影日2016-06-26 00:49:53
管理画面の現状の設定

 追記

日付や時間を表示している箇所はいくつもあるのですが、現状必要な箇所はこれになります。
どちらもメッセージが送られてからの時間を表示する関数です。約9時間遅れます。

bp_the_thread_message_time_since()
https://github.com/buddypress/BuddyPress/blob/master/src/bp-templates/bp-legacy/buddypress/members/single/messages/message.php#L41

bp_message_thread_last_post_date()
https://github.com/buddypress/BuddyPress/blob/master/src/bp-templates/bp-legacy/buddypress/members/single/messages/messages-loop.php#L101

辿ると関数定義しているのは、このファイルです。
https://github.com/buddypress/BuddyPress/blob/67f91f7fb98b90b1bc2d1f23f40d0cc936dd0302/src/bp-messages/bp-messages-template.php

ご協力ください。
よろしくお願いいたします。

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • kei344

    2016/06/24 21:10

    日付部分のコードを提示いただけませんか?

    キャンセル

回答 2

check解決した方法

0

自己解決しました。

bp_core_current_time()
https://github.com/buddypress/BuddyPress/blob/master/src/bp-core/bp-core-functions.php#L1041-L1051
上記、関数を機にbuddypressの扱っている時間がズレるようで、以下修正内容です。

前) function bp_core_current_time( $gmt = true, $type = 'mysql' ) {
後) function bp_core_current_time( $gmt = false, $type = 'mysql' ) {


アップデートに対応しない対策ではあるので、
もっといい方法あれば投稿お待ちしてます

ご協力いただいたkai334さんありがとうございました

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

0

日付周りの処理にdate関数を使われていると推測しました。その場合、date_default_timezone_set( 'asia/tokyo' ) をしても内部で date_default_timezone_set( 'UTC' ) とされているためタイムゾーンを変更できないのだと思います。date関数ではなくdate_i18n関数を使うと解消されるようです。

【【date関数を使うとずれるので】WordPressで日時を扱うときは、この関数が便利でした | 今村だけがよくわかるブログ】
https://www.imamura.biz/blog/14966

【WordPressで現在時刻を利用すると9時間ずれてしまう問題 - Qiita】
http://qiita.com/yousan/items/a385f794a9bb433aecbb

【WordPressで一部スクリプトが9時間ズレる場合の対応 | ネットに書かれていないことを綴る】
http://control.shado.jp/2010/0928115606.html

【date_i18n:WordPress私的マニュアル】
http://elearn.jp/wpman/function/date_i18n.html

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2016/06/26 00:55

    問題ないかと思います。
    管理画面内の設定のスクショを追記いたしました。
    ご確認ください。

    キャンセル

  • 2016/06/26 03:28

    すみません、管理画面内でthread_messageの時間は確認できますか?

    キャンセル

  • 2016/06/26 14:43

    管理画面内でbuddypressの時間を確認できる箇所はありません。
    メッセージが溜まっているDBを確認したところ、その時点でズレていたため
    送信時に登録される時間に誤りがあるようです。

    キャンセル

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 90.22%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる