PHPと MySQLを利用して、勤怠管理システムを作成しております。本システムの構成として、まず、会員情報を登録します。その会員情報を基に出勤、退勤時刻と日付を逐次記録し、最終的に記録したデータを一覧として表示させます。現在は、会員登録画面の設計は終了しました。以下の図は、会員登録画面の構成です。
この画面で行う操作として、まず、会員登録をしていない場合は、新規登録ボタンをクリックし、新規登録を行う。新規登録画面はログイン画面と同様で、ユーザ名とパスワードを入力して、登録を行います。登録完了後、ログイン画面で登録した情報を再度入力しログインする。次に、ログインを完了したら、以下の画面へと遷移します。
この画面で行う操作として、出勤及び退勤ボタンをクリックするだけの処理です。また、ボタンがいつ押されたか記録するために、日付と時刻をリアルタイムで表示させています。ここで、出勤または退勤ボタンをクリックしたら、以下の画面へと遷移します。今回は、説明の都合上、出勤ボタンをクリックした時の処理のみ記述する。
この画面では、「出勤しました。」のメッセージを表示させています。しかし、本来はメッセージの下にボタンがクリックされた日付と時刻を記載したが、そのやり方が分からず、現在はメッセージのみの表記となっています。
ここで、注意点がございます。先述した通り、ボタンをクリックされた日付と時刻を最終的に一覧に表示させたいです。イメージは以下の図となります。
そのためには、ボタンをクリックした日付と時刻を毎回記録しなければなりません。私はpostされたデータをセッション変数に格納するというやり方をしました。しかし、私はPHP初心者であるため、何も見ずにソースコードは書けないので、様々な記事を参照させていただきました。その結果、以下のプログラムとなりました。
<!DOCTYPE html> <html lang="ja"> <head> <meta charset="UTF-8"> <title> 出勤メッセージ</title> </head> <body> <?php $db_user = "kintai"; $db_pass = "password"; $db_host = "localhost"; $db_name = "mydb"; $db_type = "mysql"; $dsn = "$db_type:host=$db_host; dbname=$db_name; charset=utf8"; try{ $pdo = new PDO($dsn, $db_user, $db_pass); $pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); $pdo->setAttribute(PDO::ATTR_EMULATE_PREPARES, false); echo "出勤しました。<br>"; echo ""; //ボタンを押した日付と時刻を表示 }catch(PDOException $e){ echo $e->getMessage(); }try{ $PDO->beginTransaction(); $sql = "INSERT INTO user(username, password) VALUES(:username, :password)"; $stmh = $pdo->prepare($sql); $stmh->bindValue(':username', $_POST['username'], PDO::PARAM_STR); $stmh->bindValue(':password', $_POST['password'], PDO::PARAM_STR); $stmh->execute(); $pdo->commit(); }catch(PDOException $e){ $pdo->rollBack(); echo $e->getMessage(); } ?> </body> </html>
このプログラムは、「出勤しました。」のメッセージ画面です。しかし、画像では表示してないのですが、「出勤しました。」のメッセージを下にエラー文が書かれています。そのエラー文が以下です。ここで、begin.phpは上記のプログラムです。
なぜこのようなエラーが出るのか分かる方教えてください。また、このエラーを解決するためには何をすれば良いですか。
回答2件
あなたの回答
tips
プレビュー