前提・実現したいこと
ここに質問の内容を詳しく書いてください。
気づけばプロ並みという教材で学習しているのですが、サンプル通りにやっても表示されない部分があって調べてもわからないので質問します。
発生している問題・エラーメッセージ
ブラウザ上で<?php print ◯◯ ?>の◯◯の部分の文字がブラウザ上で表示されない
具体的には<?php print $pro_code; ?>と<?php print $pro_name; ?>と<?php print $pro_price; ?>
エラーメッセージ
なし
該当のソースコード
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>ろくまる農園</title> </head> <body> <?php try { $pro_code=$_GET['procode']; $dsn='mysql:dbname=shop;host=localhost;charset=utf8'; $user='root'; $password=''; $dbh=new PDO($dsn,$user,$password); $dbh->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION); $sql='SELECT name,price FROM mst_product WHERE code=?'; $stmt=$dbh->prepare($sql); $data[]=$pro_code; $stmt->execute($data); $rec=$stmt->fetch(PDO::FETCH_ASSOC); //ここがうまく行ってない、変数は空 $pro_name=$rec['name']; $pro_price=$rec['price']; var_dump($pro_name);'<br />';//中身の確認するとnullとなる $dbh=null; } catch(Exception $e) { print'ただいま障害により大変ご迷惑をお掛けしております。'; exit(); } ?>ソースコード
商品情報参照<br />
<br />
商品コード<br />
試したこと
ここに問題に対して試したことを記載してください。
echoにしたりデータベース側の問題かと思って確認したのですが、エラーをキャッチしていないので他の原因なのか思って、自分ではわからないので質問しました。
補足情報(FW/ツールのバージョンなど)
Mac bookとXAMPPを使用しています。
phpのバージョンは7.3.11です。
ここにより詳細な情報を記載してください。
「気づけばプロ並み」または「ろくまる農園」でteratail内検索してみてください。
「_」を認識していますか?
procodeとpro_codeが混在しているのに気づいていますか?
ちなみに当該書籍は回答者側の評判はすこぶる悪いです(質問が多く寄せられているところからも)
PHPマニュアル利用した学習方法に早く切り替えましょう。プロ並みにはなれません。
本は「気づけばプロ並み」、本人の質問の仕方は素人以下だな。
調べるという能力もない様ではこの先、不安しかないぞ。
これくらいでマウントだなんだ言っててはできるアドバイスはありません。
プロになりたいのなら今回の指摘がかわいいくらいに思えるようなさまざまな理不尽と戦わなければなりません。
今回の指摘を前向きなアドバイスと捉えられないのならやめたほうが吉です。
「サンプル通りにやった」のほとんどの人が「サンプル通りに書けてない」というのも事実ですよ。プログラムは書いた通りにしか動きません。
>あと混在してないですよ、目が悪いんですか?
稚拙な返し方はやめたほうがいいです。回答者への印象が悪くなれば損するのはあなたです。意図が分からないなら変に言い返すのではなく意図を聞くべき。
$_GET['procode']とGETで「procode」を指定してるけど変数は$pro_codeのようにアンダースコアを入れている。
となれば実は?pro_code=123 のようにパラメータが渡されてるのではないか?と疑うのは自然です。アクセスURLなりその前のページのコードも提示されてませんから、「混同してない」と主張するにはかなり弱いわけです。
先に書いたようにプログラムは書いた通りにしか動きませんから、疑うべきは結局そのコードを書いた人、実行した人にしかなりえないわけです。
あと大事なことなので伝えておきますと。
>エラーをキャッチしていないので
例えエラーキャッチしても出力してないので何か起きても何が問題か追える作りになってません。
また、先に指摘しておくべきでしたが、コードはマークダウンのcode機能を利用してご提示ください。
でないとこちらの手元で「質問者の現象が再現できるコード」になってません。行頭詰められてますしコピーボタンもありません。
初めて使うのでしたらヘルプをきちんと読んでから質問しましょう。
噛みつくのはやるべきことをきちんとやってからです。
サンプル通り書くと動かない場所が多いのもこの書籍の特徴
正誤表をネットで確認したんだろうか? http://www.ric.co.jp/book/error/error1065.html
正誤表の内容が初心者並みというのも書籍の信頼性を損ねますね。
著者本人の try-catch で握りつぶした例外の確認方法もお粗末
↓
谷藤 賢一 catchに飛んだということは、何か本体に不具合が起きております。tryとそれに付随する括弧と、catchのブロック全部をコメントアウトして動かしてみてください。
Fatalエラーが出ると思います。その行を調べてみてください
参考情報、写経した方の記事: https://budougumi0617.github.io/2019/11/25/review_pronami_php/ GitHubに写経したコードがあるらしいので、関係するところを比較してみてはいかがだろうか。
書籍を盲信せずにPHPマニュアル読みましょうと注意喚起してくれてるだけの存在ですね。書籍のタイトル変えるべき。
気づけば初心者並みPHP
不快にさせられたので通報しました。
気づけば暴言野郎並みPHP
回答1件
あなたの回答
tips
プレビュー