提示コードのstaff_dips.phpのコメント部で以下のようなエラーがでます。これは何が原因なのでしょうか?変数を追いかけましたが初学者なのでわかりません。var_dump関数を使ってコメント部の変数の値を調べましたが別のエラーがでてデバッグできません。そもそも
phpのデバッグはどうやるのでしょうか?
参考サイト: https://techplay.jp/column/571
日本語訳
タイプboolの値の配列オフセットにアクセスしようとしています
#####原文
Notice: Trying to access array offset on value of type bool in /opt/lampp/htdocs/staff/staff_disp.php on line 26
staff_list.php
php
1<!DOCTYPE html> 2<html> 3 <head> 4 <meta charset="UTF-8"> 5 <title> ろくまる農園</title> 6 </head> 7 <body> 8 9 <?php 10 11 12 try 13 { 14 $dsn = 'mysql:dbname=shop;host=localhost;charset=utf8'; 15 $user = 'root'; 16 $password = ''; 17 18 $dbh = new PDO($dsn,$user,$password); 19 $dbh->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION); 20 21 $sql = 'SELECT code,name FROM mst_staff WHERE 1'; 22 23 $stmt = $dbh->prepare($sql); 24 $stmt->execute(); 25 26 $dbh = null; 27 28 print '<form method="post" action="staff_branch.php">'; 29 30 print 'スタッフ一覧<br/>'; 31 32 while(true) 33 { 34 $rec = $stmt->fetch(PDO::FETCH_ASSOC); 35 if($rec == false) 36 { 37 break; 38 } 39 40 print '<input type="radio" name="staffcode" value="'.$rec['code'].'">'; 41 42 43 print $rec['name']; 44 print '<br />'; 45 46 } 47 48 print '<input type ="submit" name="disp" value="参照">'; 49 print '<input type ="submit" name="edit" value="修正">'; 50 print '<input type ="submit" name="delete" value="削除">'; 51 print '<input type ="submit" name="add" value="追加">'; 52 print '</form>'; 53 54 }catch(Eception $e) 55 { 56 print '只今障害のためご迷惑おおかけしています。'; 57 exit(); 58 } 59 60 61 ?> 62 63 64 </body> 65 66</html> 67
staff_brutch.php
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ブランチ </title> </head> <body> <?php if(isset($_POST['disp']) == true) { if(isset($_POST['staffcode']) == false) { header('Location:staff_ng.php'); } $staff_code = $POST['staffcode']; header('Location:staff_disp.php?staffcode='.$staff_code); exit(); } if(isset($_POST['add']) == true) { header('Location:staff_add.php'); exti(); } if(isset($_POST['edit']) == true) { if(isset($_POST['staffcode']) == false) { header('Location:staff_ng.php'); exit(); } $staff_code = $_POST['staffcode']; header('Location:staff_edit.php?staffcode='.$staff_code); print '修正ボタンが押されました。'; }else if(isset($_POST['delete']) == true) { if(isset($_POST['staffcode']) == false) { header('Location:staff_ng.php'); exit(); } $staff_code = $_POST['staffcode']; header('Location:staff_delete.php?staffcode='.$staff_code); print '削除ボタンが押されました。'; } ?> </body> </html>
staff_disp.php
<!DOCTYPE html> <html> <head> <meta chaset="UTF-8"> <title> エディット </title> </head> <body> <?php try { $staff_code = $_GET['staffcode']; $dbn = 'mysql:dbname=shop;host=localhost;charset=utf8'; $user = 'root'; $password=''; $dbh = new PDO($dbn,$user,$password); $dbh->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION); $sql = 'SELECT name FROM mst_staff WHERE code=?'; $stmt = $dbh->prepare($sql); $data[] = $staff_code; $stmt->execute($data); $rec = $stmt->fetch(PDO::FETCH_ASSOC); ///////////////////////////////////////////////////////////////////////////////// $staff_name = $rec['name']; ///////////////////////////////////////////////////////////////////////////////// $dbh= null; }catch(Exception $e) { print '只今障害によりご迷惑をおかけしています。'; exit(); } ?> スタッフ情報<br/> スタッフコード<br /> <?php print $staff_name;?> <br /> <br /> <form> <input type="submit" value="戻る"> </form> </body> </html>
あなたの回答
tips
プレビュー