下記のようなコードを、他の方のサイトを参考に打ち込んでいました。
register_submit.phpで、
$user = $_POST["user"];31行目
この部分にNotice: Undefined index:が出ます。
前二つのファイルでPOSTをしているのにエラーが出るのはなぜなのでしょうか・・・。
一度コメントアウトしてみたところエラーは出なくなりましたが、
これで正常動作といえるのかがわかりません。
他にもおかしなところがありましたらご指摘お願いします。
register.php
<?php session_start(); header("Content-type: text/html; charset=utf-8"); //パラメーター取得 // $id = $_POST['id']; // $password = $POST['password']; ?> <!DOCTYPE html> <html lang="ja"> <head> <meta charset="UTF-8"> <script src="passwordchecker.js" type="text/javascript"></script> <script src="common.js" type="text/javascript"></script> <script type="text/javascript"> /* 登録前チェック */ function conrimMessage(){ var username = document.getElementById('user').value; var mail = document.getElementById('mail').value; var pass = document.getElementById('password').value; var conf = document.getElementById('confirm_password').value; //必須チェック if((use == "")||(mail == "")||(pass == "")||(conf == "")){ alert("必須項目は入力して下さい"); return false; } //パスワードチェック if(pass != conf){ alert("パスワードが一致しません"); return false; } if(passwordLevel < 3){ return confirm("パスワード強度が低いです。このまま登録しますか?"); } return true; } </script> </head> <body> <h1>登録画面</h1> <?php if($_SESSION['error_status'] == "1"){ echo "<h2 style='color:red';>入力内容に誤りがあります</h2>"; } if($_SESSION['error_status'] == "2"){ echo "<h2 style='color:red';>そのIDは既に使われています</h2>"; } if($_SESSION['error_status'] == "3"){ echo "<h2 style='color:red';>タイムアウトか不正なURLです</h2>"; } if($_SESSION['error_status'] == "4"){ echo "<h2 style='color:red';>登録に失敗しました</h2>"; } ?> <style> input{ vertical-align:middle; position:relative; } </style> <form action="register_check.php" method="post" onsubmit="return conrimMessage();"> メールアドレス<input type="text" name="mail" id="mail"><br /> ID <input type="text" name="user" id="username"><br /> パスワード<br /> <input type="password" name="password" id="password" onkeyup="setMessage(this.value);"> <div id="pass_message"></div> パスワード(確認)<br /> <input type="password" name="confirm_password" id="confirm_password" onkeyup="setConfirmMessage(this.value);"><br /> <input type="submit" value="登録"> <input type="reset" value="リセット"> <input type="button" value="戻る" onclick="history.back();"> </form> </body> </html>
register_check.php
<?php require_once("function.php"); session_start(); header("Content-type: text/html; charset=utf-8"); $_SESSION["token"] = get_csrf_token(); $user = $_POST['user']; $mail = $_POST["mail"]; $password = $_POST["password"]; $confirm_password = $_POST["confirm_password"]; if($password != $confirm_password){ //pass不一致 $_SESSION["error_status"] = 1; header("HTTP/1.1 301 Moved Permanently"); header("Location: register.php"); exit(); } //IDcheck //DB接続 ※ $dsn = 'mysql:host=localhost;dbname=portfolio;charset=utf8'; $user = 'root'; $password = ''; $dbh = new PDO($dsn,$user,$password); $dbh->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION); //プレースホルダでSQL作成 ※ $sql = "SELECT COUNT(*) AS CNT FROM USERS WHERE ID = ?;"; //パラメータの型指定 ※ $stmt = $dbh->prepare($sql, array('text')); //パラメータを渡してSQL実行 $rs = $stmt->execute(array($user)); // try{ // $pdo = new PDO( // 'mysql:host=localhost;dbname=portfolio;charset=utf8', // 'root', // ''; // [ // PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION, // PDO::ATTR_DEFAULT_FETCH_MODE => PDO:: FETCH_ASSOC, // ] // ); // }catch(PDOException $e){ // header('Content-Type: text/plain; charset=UTF-8', true , 500); // exit($e->getMessage()); // } while ($row = $stmt->fetch()){ $count = $row['CNT']; } $dbh = null; //IDがすでに登録されていた場合 if($count != 0){ $_SESSION['error_status'] = 2; header("HTTP/1.1 301 Moved Permanently"); header("Location: register.php"); exit(); } //エラー情報リセット $_SESSION['error_status'] = 0; ?> <!DOCTYPE html> <html lang="ja"> <head> <meta charset="UTF-8"> </head> <form action="register_submit.php" method="post" > <table border="0"> <tr> <td>ID</td> <td><?php echo htmlspecialchars($user , ENT_QUOTES , "UTF-8"); ?></td> <td>メールアドレス</td> <td><?php echo htmlspecialchars($mail , ENT_QUOTES , "UTF-8"); ?></td> </table> <input type="hidden" name="id" value="<?php echo htmlspecialchars($user , ENT_QUOTES , "UTF-8") ?>" > <input type="hidden" name="mail" value="<?php echo htmlspecialchars($mail , ENT_QUOTES , "UTF-8") ?>" > <input type="hidden" name="password" value="<?php echo htmlspecialchars($password , ENT_QUOTES , "UTF-8") ?>" > <input type="hidden" name="token" value="<?php echo htmlspecialchars($_SESSION['token'] , ENT_QUOTES , "UTF-8") ?>" > <input type="submit" value="登録"> <input type="reset" value="リセット"> <input type="button" value="戻る" onclick="history.back();"> </form> </body> </html>
register_submit.php
<?php // Notice: Undefined index: username in C:\xampp\htdocs\portfolio\register_submit.php on line 22 // // Warning: str_replace() expects at least 3 parameters, 1 given in C:\xampp\htdocs\portfolio\register_submit.php on line 73 // // Warning: mb_send_mail(): Failed to connect to mailserver at "localhost" port 25, verify your // "SMTP" and "smtp_port" setting in php.ini or use ini_set() in C:\xampp\htdocs\portfolio\register_submit.php on line 82 require_once("function.php"); session_start(); header("Content-type: text/html; charset=utf-8"); //CSRFチェック if($_SESSION['token'] != $_POST['token']){ $_SESSION = array(); session_destroy(); session_start(); $_SESSION["error_status"] = 2; header("HTTP/1.1 301 Moved Permanently"); header("Location: register.php"); exit(); } //エラー情報のリセット $_SESSION["error_status"] = 0; $user = $_POST["user"]; $mail = $_POST["mail"]; $password = $_POST["password"]; //ソルト作成 $salt = get_salt(); //一時URLパスワード作成 $url_pass = get_url_password(); //ユーザー仮登録 //ストレッチングパスワード $hash = stretchedPassword($salt,$password); //データベース接続 $dsn = 'mysql:dbname=portfolio;host=localhost;charset=utf8mb4'; $user = 'root'; $password = ''; $dbh = new PDO($dsn,$user,$password); $dbh->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION); //プレースホルダでSQL作成 $sql = "INSERT INTO USERS (ID,SALT,PASSWORD,MAILADDRESS, TEMP_PASS,LAST_CHANGE_PASS_TIME,RESISTER_TIME)"; $sql .= "VALUES(?,?,?,?,?,?,?);"; //パラメータの型を指定 $stmt = $dbh->prepare($sql,array('text','text','text','text','text','timestamp','timestamp')); //パラメータを渡してSQL実行 $res = $stmt->execute(array($user,$salt,$hash,$mail,$url_pass,date('Y-m-d H:i:s'),date('Y-m-d H:i:s'))); //ID重複チェック ※ try{ }catch(PDOException $e){ die("接続失敗です{$e->getMessage()}"); $dbh = null; $_SESSION['error_status'] = 4; header("HTTP/1.1 301 Moved Permanently"); header("Location: register.php"); exit(); } $dbh = null; //ユーザーに確認メール送信 $mail = str_replace(["/r" , "/n"] , "" , $mail); $url = "http://" . SERVER . "/register_confirm.php?" . $url_pass; $msg = "以下のアドレスからアカウントを有効にしてください。" . PHP_EOL; $msg .= "アドレスの有効期限は10分間です。" . PHP_EOL; $msg .= "有効時間が過ぎたらパスワードのリセットをしてください" . PHP_EOL . PHP_EOL; $msg .= $url; mb_send_mail($mail,"ユーザー登録",$msg,"From:" . SENDER_EMAIL); ?> <!DOCTYPE html> <html> <head> <meta charset="utf-8"> </head> <body> <h1>仮登録完了</h1> 仮登録が完了しました。<br /> 登録を完了するには送信されたメールで手続きを行ってください。<br /> </body> </html>
回答5件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
退会済みユーザー
2017/08/10 10:46