お世話になります。現在ログイン機能を持つプログラムを作成しておりますがタイトルの問題が発生しドはまりしております。
login
<?php session_start(); ?> <?php include("../common_function.php"); ?> <?php if(!empty($_POST)){ /*-------------------------------------サニタライズ(始)------------------------------------------*/ foreach( $_POST as $key => $value ) { $clean[$key] = htmlspecialchars( $value, ENT_QUOTES); } /*-------------------------------------サニタライズ(終)------------------------------------------*/ mb_convert_kana("$clean", "n"); //print_r($clean); $user_name =$clean['user_name']; $password =$clean['password']; $errors = array(); if ($user_name == '') { $errors['$user_name'] = '※ メールアドレスが未入力です'; } if ($password == '') { $errors['$password'] = '※ パスワードが未入力です'; } if (empty($errors)) { $pdo = new PDO(dsn,user,password); $sql = "SELECT * FROM user_list WHERE (user_name = '$user_name') AND (user_password = '$password')"; $statement = $pdo->prepare($sql); $statement->execute(); $row = $statement->fetch(); // レコードの取り出し //print_r($row); if ($row) // 該当レコードがあったら { $_SESSION['name'] = $row['user_name']; //print_r($_SESSION); // index.phpに飛ばす header('Location:/index.php'); exit(); } else // もし該当レコードがなかったら { $errors['fales'] = '※ メールアドレスかパスワードが間違っています'; } } } ?>
index
<?php session_start(); ?> <?php include("common_function.php"); ?> <?php include("$webroot/src/head.php"); ?> <!--ヘッダー--> <?php include_once("$webroot/common_parts/header.php")?> <!--/ヘッダー--> <main class="container mb-5"> <div class="mb-5"> <?php print_r($_SESSION) ;?> //ここでセッションを確認してる
一応「header(Location)」前でsessionに値が持てていることは確認できています。問題はリダイレクト時に値が空になっていることです。色んなサイトで似た状態の記事をたくさん読み、改善を試みましたが全部外れています。
分かっている事は、「FireFox」でのみsessionの値が引き継がれ、「IE」と「Google chorome」では値が引き継がれませんでした。ブラウザのセキュリティかとも思いましたが、どうもそういうことでもないようです。
このような状態で、改善の心当たりのある有識者様がいらっしゃいましたらご教授をお願いいたします。
まだ回答がついていません
会員登録して回答してみよう