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

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

新規登録して質問してみよう
ただいま回答率
85.48%
MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

Q&A

解決済

3回答

10082閲覧

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

GrGrKkKk

総合スコア16

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

1グッド

0クリップ

投稿2016/07/12 16:45

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

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

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

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

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

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

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

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

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

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

yodel👍を押しています

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

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

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

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答3

0

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

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

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

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

投稿2016/07/12 18:47

tanat

総合スコア18713

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

GrGrKkKk

2016/07/23 15:36

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

0

ベストアンサー

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

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

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

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

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

投稿2016/07/13 03:25

yambejp

総合スコア114839

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

GrGrKkKk

2016/07/23 15:33

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

0

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

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

投稿2016/07/12 17:29

takasima20

総合スコア7458

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

GrGrKkKk

2016/07/23 15:38

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問