質問をすることでしか得られない、回答やアドバイスがある。

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

ただいまの
回答率

88.92%

PHP画面遷移のデータ保持方法に関してベストプラクティスは?

解決済

回答 3

投稿

  • 評価
  • クリップ 0
  • VIEW 8,499

GrGrKkKk

score 12

はじめまして
始めて投稿させていただきます。

概念的な質問で恐縮ですが、PHPの画面遷移時の最善策について、教えていただきたいと思います。

現在、ECではないのですが予約に関するサイトの開発案件を抱えておりまして、画面遷移時のデータ保持に関するところで壁にぶつかりました。

操作動線の流れとしては
1.トップ画面で商品検索
2.商品と個数を送信
3.発注内容確認表示と受け取りの支店選択(支店が出張先になることがあり、状況に応じて住所入力)
4.最終内容確認画面
5.予約発注確定
(予約確定後には、先方の管理画面で依頼内容の一覧や集計ができるようになっている)

となりますが、内容修正のために前の画面に戻ることがあり、前の画面に戻るときは流れに逆行する形になるので、ユーザーから受け取った$_POSTを扱うことができないので、何らかの方法でデータを保持しなければならないと思うのですが、

1.セッション変数
2.mySQLに画面ごとの情報を保存
3.hiddenフィールドにハッシュ化して保持

を考えましたがどのような方法が一般的なのでしょうか?

また、セッション変数を使う場合、メモリーの圧迫などを考慮する必要はあるのでしょうか?

特に、前の画面に戻るときのデータ保持に難しさを感じております。

以上、何卒よろしくお願いします。

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

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

回答 3

+2

セッション情報の永続化が必要かどうか(例えば注文処理の途中の画面でセッション情報が切れた場合に、最初からやり直すことが許容されるのか?)
ロードバランサー等によるスケールアウト(Webサーバの複数台化)が必要かどうか
によってベストプラクティスは変わってきます。

両方いらない場合はセッション変数で処理してしまうのがベストかと思います。
セッション情報自体はファイルとして保存されるので、1ユーザあたりのセッション情報が異常に多い場合以外はメモリの圧迫は気にしなくてOKです。

hiddenでもいいのですが、hiddenの情報はユーザが任意に書き換えることが出来るので、悪意のあるユーザが変な使い方をする余地が発生し、その辺のチェックもしっかりしないといけなくなって複雑性が増します。

永続化とスケールアウトのどちらかでも必要な場合は、
MySQL等のRDBMSやRedis,memcahed等のkey-valueストアにセッション情報を保存して、
セッション情報の永続化(Redis,memcahed等ではさらに別途注意が必要)と
複数のwebサーバからアクセスできるようにする(スケールアウト)
を実現させる必要が出てきますね。

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2016/07/24 00:36

    この度はお礼が遅くなり申し訳ありませんでした。
    総合的に全体的に考慮すべき点を挙げていただけたので、大変参考になりました。
    心より御礼申し上げます。

    キャンセル

checkベストアンサー

+1

登録の流れとしては
入力→バリデート→修正→確定前最終確認→確定・登録→登録完了

この内、入力から最終確認までの間は、なんでもいい
一番いいのはセッションですが、普通にINPUTで引き継いでもいいし
クッキーでもいい。逆にhiddenである必要はない
登録前のデータをDBに保存しておく必要もない

最終確認から確定・登録へデータを引き継ぐ場合は
セッションの一択
ほかの方法だとユーザーが悪意を持って偽装できるので
最終確認画面をだす意味がなくなる

内容修正のために前の画面に戻る

前の画面に戻るのではなく修正画面に進んでください

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2016/07/24 00:33

    この度はお礼が遅くなり申し訳ありませんでした。
    簡潔にお答えいただきありがとうございます!!
    非常にわかりやすい内容でしたので、ベストアンサーとさせていただきました。
    重ねて御礼申し上げます。

    キャンセル

+1

セッション変数ですかねえ。
次点で hidden かなあ。
データベースには基本的に確定した情報を書き込むべきだと考えます。

通常の画面で入力するくらいの情報でしたら
メモリの圧迫は考えなくてもいいと思います。
まあ、Webシステムという時点でできることは
ある程度限られてきますから、あとは自分たちの
設計した内容と照らしてチョイスしていくしかないかと。

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2016/07/24 00:38

    この度はお礼が遅くなり申し訳ありませんでした。
    具体的な手段をお示しいただき、誠にありがとうございます。
    大変参考になりました。
    心より御礼申し上げます。

    キャンセル

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

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

関連した質問

同じタグがついた質問を見る