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

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

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

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

Q&A

解決済

2回答

806閲覧

PHP、セッション変数についての質問です

退会済みユーザー

退会済みユーザー

総合スコア0

PHP

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

0グッド

0クリップ

投稿2017/11/25 10:12

初めまして、現在勉強の為に公開を目的としないECサイトを作成しているのですが、商品詳細画面からカートに商品を登録する場合、どのように商品データをcartに登録するのがよいですか?

ちなみに、私はセッション変数を使用して商品コードや個数などを次ぺージにもっていきたいと思っています。
このほかに何かいい案等がございましたら、ご教示願います。

また、ソースコードに関しても、実際にPOSTで受け取った値をセッション変数に格納して次ページにもっていくやり方なども曖昧でわかっていない為、そちらもご教示願います。
現在の商品詳細画面のソースコードは下記に記載しておきます。
セキュリティー対策につきましては、今回全て出来上がり次第復習をかねて、もう一度ECサイトを作成しようと思っているのでその時に対策はします。

<?php session_start(); require 'DB.php'; $header = ''; $code = $_GET['code']; //DBからGETで受け取った商品codeのデータを取り出す $DB = DB_connect(); $stmt=$DB->query("SELECT * FROM goods WHERE code =".$code); //ログイン状態を見て、表示するヘッダーを変更 if(isset($_SESSION['NAME'])) { $header = '<a href="http://192.168.1.11/shop/userkanri/userMypage.php">マイページ</a>'; } if(!isset($_SESSION['NAME'])) { $header = '<a href="http://192.168.1.11/shop/userkanri/Login.php">ログイン</a>'; } ?> <!DOCTYPE html> <html lang="ja"> <head> <meta charset="utf-8"> <link rel="stylesheet" href="itemdetail.css"> <title>KotetuGAMES</title> </head> <body> <header> <div class="header-wrap"> <div class="header-logo"> <h1>KotetuGAMES</h1> </div> <div class="header-list"> <ul> <li><?php echo $header ?></li> <li><a href="http://192.168.1.11/shop/cart/cart.php">カート</a></li> <li>お問い合わせ</li> <li><a href="http://192.168.1.11/shop/topPage.php">トップページ</a></li> </ul> </div> </div> </header>
<div class="itemdetail"> <?php foreach($stmt as $value): ?> <?php echo '<h1>'.$value['name'].'</h1><img src="http://192.168.1.11/shop/images/'.$value['path'].'"><h2>価格:¥ '.$value['price'].'</h2>' ?> <?php endforeach ?> </div> <div class="form"> <form action="cart/cart.php" method="post"> <span>数量:</span> <select name="num"> <option value="1">1</option> <option value="2">2</option> <option value="3">3</option> </select> <input type="hidden" name="code" value="<?php echo $code ?>"> <input type="submit" name="addcart" value="カートにいれる"> </form> </div>
<footer> </footer> </body> </html>

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

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

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

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

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

退会済みユーザー

退会済みユーザー

2017/11/25 11:12

インデントなどがなくなって読みにくくなるので、ソースコードは <code> ボタンを押して、シンタックス機能を利用して読みやすくしてください。
退会済みユーザー

退会済みユーザー

2017/11/25 11:22

セッション以前に、商品リストが表示されていないのでは?
退会済みユーザー

退会済みユーザー

2017/11/25 12:34

すみません、商品リストはトップページでの表示となっております。次からはソースコードはそういった形で載せます
退会済みユーザー

退会済みユーザー

2017/11/25 12:37

質問は編集できますので、次からではなく、この質問から変えてはいかがでしょう。また、ソースコードはシンタックス機能を使って、見やすく投稿しましょう。
退会済みユーザー

退会済みユーザー

2017/11/25 12:38

承知しました!帰宅次第、修正しますね
guest

回答2

0

ベストアンサー

te2jiさんがしつこいので…

投稿2017/11/26 03:45

退会済みユーザー

退会済みユーザー

総合スコア0

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

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

0

php の session は、cookie か URLパラメータ で引き継ぐものなので、ブラウザが変わると引き継ぐことが出来ません。
その為。カート系の実装としてはユーザ情報に紐付けておいたほうが柔軟性が高いと思います。

例)スマホでカートに入れるところまでやったが、配送先を入力するのが面倒くさかったため、PCで入力し直そうと思った時に、ブラウザが変わることになり、PCで再度カートに入れ直さなければならない等が発生する。

前の質問にも書きましたが、コードは見るに耐えないので見ていません。

php のマニュアルはよく出来ており、サンプルも豊富なので、session の利用方法に関しては、マニュアルを参照するのが良いです。
セッション関連

セキュリティ的な課題点は IPA 資料を参照すると良いです。
安全なウェブサイトの作り方

投稿2017/11/26 01:08

退会済みユーザー

退会済みユーザー

総合スコア0

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

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

退会済みユーザー

退会済みユーザー

2017/11/26 01:29

質問に答えて下さるのは構わないのですが、見るに耐えないのでしたらわざわざ僕の質問見ていただなくても結構なのですが、ましてやそれを伝える必要はありますか? 確かにあなたの回答は素晴らしいと思いますが不快に思わせるコメントはどうかと思います
退会済みユーザー

退会済みユーザー

2017/11/26 01:50

前の回答にも書きましたが、コードに突っ込みどころが多すぎて、回答がブレるので、質問する際には「質問主旨に必要な箇所のみにコードをフォーカス」することが必要です。問題が多いことを自身で理解されているのであればなおさらです。 以前の回答へのコメントで > 質問内容を変更し、もう少し的を絞って質問しなおしてみようと思います。 とあるにも関わらず、反映がないため今回の回答は強めの言葉を選んでいます。指摘事項に対して「わかった」と返事した内容が直後に否定される方が多分不快ですよ。 コードは、Kosuke_Shibuya さんのアドバイス「<code> ボタンを押して、シンタックス機能を利用して読みやすくしてください。」を反映するとともに、「質問主旨に必要な箇所のみにコードをフォーカス」し直すことを改めて提案します。
退会済みユーザー

退会済みユーザー

2017/11/26 03:05

自分なりに反映したつもりだったんですけど、あなたがそう思うならもう放っておいたらいいだけじゃないですか? お節介はいいんですが、現にこっちは不快に思ってるわけですし、あなたは回答側なので不快なら回答しない選択肢はあると思いますがこちらはあなたからのコメントに対処しようがないので…
退会済みユーザー

退会済みユーザー

2017/11/26 03:22

>前の質問にも書きましたが、コードは見るに耐えないので見ていません。 上記のコメントは、本質的にはEC関連の質問に対して、コードをレビューしなかったことへのエクスキューズです。 実はそれほど不快には思っていません。質問者なんてそんな方いっぱいいるので。 一つ前のコメントはタダの警告です。理解されていないようなのでちゃんと書きますが、そろそろ Kosuke_Shibuya さんがブチ切れてもおかしくないです。 ちゃんと対応したほうが良いですよ^^; > お節介はいいんですが、現にこっちは不快に思ってるわけですし、あなたは回答側なので不快なら回答しない選択肢はあると思いますがこちらはあなたからのコメントに対処しようがないので… 通報ボタンがあるのでそちらをどうぞ。ちゃんと「不快な投稿」って用意されています。
退会済みユーザー

退会済みユーザー

2017/11/26 03:26

実はそれ程不快に思っていないのにそれを書く、勝手に他人を巻き込みブチ切れますよのコメント、なんだか友達いなさそうですね…。通報は既に行なっていますがブロック機能などがないのであなたに対処出来ませんってことなのですがσ(^_^;) これ以上文句があるのでしたらTwitter等でお願いしますσ(^_^;) あ、返信は結構ですのでσ(^_^;)
退会済みユーザー

退会済みユーザー

2017/11/26 23:40

友達って^^;学生さんだったんですかね。。。退会されたようで、少し申し訳ないことをしました。 社会人になると「やる」と言ったことをやらない、わからないことを「わかった」という。これらはそれだけで悪です。誰からも等しく信頼を失い、関係者からは怒られる事なので、今後注意したほうが良いです。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問