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

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

ただいまの
回答率

91.35%

  • PHP

    15214questions

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

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

解決済

回答 2

投稿 2017/11/25 19:12

  • 評価
  • クリップ 0
  • VIEW 145
退会済みユーザー

退会済みユーザー

初めまして、現在勉強の為に公開を目的としない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>

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

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

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

  • 退会済みユーザー

    退会済みユーザー

    2017/11/25 21:34

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

    キャンセル

  • Kosuke_Shibuya

    2017/11/25 21:37

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

    キャンセル

  • 退会済みユーザー

    退会済みユーザー

    2017/11/25 21:38

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

    キャンセル

回答 2

check解決した方法

0

te2jiさんがしつこいので…

投稿 2017/11/26 12:45

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

-1

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

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

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

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

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

投稿 2017/11/26 10:08

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2017/11/26 10:29

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

    キャンセル

  • 2017/11/26 10:50

    前の回答にも書きましたが、コードに突っ込みどころが多すぎて、回答がブレるので、質問する際には「質問主旨に必要な箇所のみにコードをフォーカス」することが必要です。問題が多いことを自身で理解されているのであればなおさらです。

    以前の回答へのコメントで
    > 質問内容を変更し、もう少し的を絞って質問しなおしてみようと思います。

    とあるにも関わらず、反映がないため今回の回答は強めの言葉を選んでいます。指摘事項に対して「わかった」と返事した内容が直後に否定される方が多分不快ですよ。

    コードは、Kosuke_Shibuya さんのアドバイス「<code> ボタンを押して、シンタックス機能を利用して読みやすくしてください。」を反映するとともに、「質問主旨に必要な箇所のみにコードをフォーカス」し直すことを改めて提案します。

    キャンセル

  • 2017/11/26 12:05

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

    キャンセル

  • 2017/11/26 12:22

    >前の質問にも書きましたが、コードは見るに耐えないので見ていません。
    上記のコメントは、本質的にはEC関連の質問に対して、コードをレビューしなかったことへのエクスキューズです。
    実はそれほど不快には思っていません。質問者なんてそんな方いっぱいいるので。

    一つ前のコメントはタダの警告です。理解されていないようなのでちゃんと書きますが、そろそろ Kosuke_Shibuya さんがブチ切れてもおかしくないです。

    ちゃんと対応したほうが良いですよ^^;

    > お節介はいいんですが、現にこっちは不快に思ってるわけですし、あなたは回答側なので不快なら回答しない選択肢はあると思いますがこちらはあなたからのコメントに対処しようがないので…

    通報ボタンがあるのでそちらをどうぞ。ちゃんと「不快な投稿」って用意されています。

    キャンセル

  • 2017/11/26 12:26

    実はそれ程不快に思っていないのにそれを書く、勝手に他人を巻き込みブチ切れますよのコメント、なんだか友達いなさそうですね…。通報は既に行なっていますがブロック機能などがないのであなたに対処出来ませんってことなのですがσ(^_^;)

    これ以上文句があるのでしたらTwitter等でお願いしますσ(^_^;)
    あ、返信は結構ですのでσ(^_^;)

    キャンセル

  • 2017/11/27 08:40

    友達って^^;学生さんだったんですかね。。。退会されたようで、少し申し訳ないことをしました。

    社会人になると「やる」と言ったことをやらない、わからないことを「わかった」という。これらはそれだけで悪です。誰からも等しく信頼を失い、関係者からは怒られる事なので、今後注意したほうが良いです。

    キャンセル

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

ただいまの回答率

91.35%

関連した質問

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

  • PHP

    15214questions

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