下記【もとのコード】はMySQLを使ったログインのためのコードです。(login.php)
ログインが成功したら
$MM_redirectLoginSuccess = "index.php";
という形でindex.phpに飛ばしています。
login.php →ログイン成功→ index.php
という形で飛んでいきます。
【やりたい事】
このコードを改造して、
login.php?buy_pass=1234567という形でアクセスされて、ログインが成功したら
login.php?buy_pass=1234567 →ログイン成功→ index.php?buy_pass=1234567
という形でクエリーも一緒にredirectしたいと考えています。
【試したこと】【試したコード】
$MM_redirectLoginSuccess = "index.php";
の部分を下記のように書き換えました。
$pass_urlencode= urlencode($_GET['buy_pass']);
$MM_redirectLoginSuccess = "index.php?buy_pass={$pass_urlencode}";
【結果】
index.php?buy_pass= まではリダイレクトできましたが、1234567の欄は空欄のままでした。
どこが間違っているかご指摘戴けますでしょうか?
<?php // *** Validate request to login to this site. if (!isset($_SESSION)) { session_start(); } $loginFormAction = $_SERVER['PHP_SELF']; if (isset($_GET['accesscheck'])) { $_SESSION['PrevUrl'] = $_GET['accesscheck']; } if (isset($_POST['userId'])) { $loginUsername=$_POST['userId']; $password=$_POST['pass']; $MM_fldUserAuthorization = ""; $MM_redirectLoginSuccess = "index.php"; $MM_redirectLoginFailed = "login_err.php"; $MM_redirecttoReferrer = false; mysql_select_db($database_value_cars, $value_cars); $LoginRS__query=sprintf("SELECT userId, pass FROM a_user WHERE userId=%s AND pass=%s", GetSQLValueString($loginUsername, "text"), GetSQLValueString($password, "text")); $LoginRS = mysql_query($LoginRS__query, $value_cars) or die(mysql_error()); $loginFoundUser = mysql_num_rows($LoginRS); if ($loginFoundUser) { $loginStrGroup = ""; if (PHP_VERSION >= 5.1) {session_regenerate_id(true);} else {session_regenerate_id();} //declare two session variables and assign them $_SESSION['MM_Username'] = $loginUsername; $_SESSION['MM_UserGroup'] = $loginStrGroup; if (isset($_SESSION['PrevUrl']) && false) { $MM_redirectLoginSuccess = $_SESSION['PrevUrl']; } header("Location: " . $MM_redirectLoginSuccess ); } else { header("Location: ". $MM_redirectLoginFailed ); } } ?>【もとのコード】>>>>>>>>>>>>>>>>>>>>>
<?php // *** Validate request to login to this site. if (!isset($_SESSION)) { session_start(); } $loginFormAction = $_SERVER['PHP_SELF']; if (isset($_GET['accesscheck'])) { $_SESSION['PrevUrl'] = $_GET['accesscheck']; } if (isset($_POST['userId'])) { $loginUsername=$_POST['userId']; $password=$_POST['pass']; $MM_fldUserAuthorization = ""; $pass_urlencode= urlencode($_GET['buy_pass']); $MM_redirectLoginSuccess = "index.php?buy_pass={$pass_urlencode}"; $MM_redirectLoginFailed = "login_err.php"; $MM_redirecttoReferrer = false; mysql_select_db($database_value_cars, $value_cars); $LoginRS__query=sprintf("SELECT userId, pass FROM a_user WHERE userId=%s AND pass=%s", GetSQLValueString($loginUsername, "text"), GetSQLValueString($password, "text")); $LoginRS = mysql_query($LoginRS__query, $value_cars) or die(mysql_error()); $loginFoundUser = mysql_num_rows($LoginRS); if ($loginFoundUser) { $loginStrGroup = ""; if (PHP_VERSION >= 5.1) {session_regenerate_id(true);} else {session_regenerate_id();} //declare two session variables and assign them $_SESSION['MM_Username'] = $loginUsername; $_SESSION['MM_UserGroup'] = $loginStrGroup; if (isset($_SESSION['PrevUrl']) && false) { $MM_redirectLoginSuccess = $_SESSION['PrevUrl']; } header("Location: " . $MM_redirectLoginSuccess ); } else { header("Location: ". $MM_redirectLoginFailed ); } } ?>【試したコード】>>>>>>>>>>>>>>>>>>>>>
回答1件
あなたの回答
tips
プレビュー