ユーザーがログインしたときに、すべての mysql 情報を取得するにはどうすればよいですか? 登録システムとログインシステムがあります。ユーザーがログインするとき、ユーザー名とパスワードを入力します。入力できる変数はこれら 2 つだけです。ユーザーが入力したものではない、そのプロファイルの他のすべての変数を取得するにはどうすればよいでしょうか。ユーザー名は一意です。すべての php ファイルで使用する残りの変数を取得するにはどうすればよいですか?
私のログインファイル:
<?
/*Use of Sessions*/
if(!session_id())
session_start();
header("Cache-control: private"); //avoid an IE6 bug (keep this line on top of the page)
$login='NO data sent';
/*simple checking of the data*/
if(isset($_POST['login']) && isset($_POST['pass']))
{
/*Connection to database logindb using your login name and password*/
$db=mysql_connect('localhost','teachert_users','dogs1324') or die(mysql_error());
mysql_select_db('teachert_users');
/*additional data checking and striping*/
$_POST['login']=mysql_real_escape_string(strip_tags(trim($_POST['login'])));
$_POST['pass']=mysql_real_escape_string(strip_tags(trim($_POST['pass'])));
$_POST['pass']=md5($_POST['pass']);
$_POST['pass']=strrev($_POST['pass']);
$_POST['pass']=md5($_POST['pass']);
$_POST['pass'].=$_POST['pass'];
$_POST['pass']=md5($_POST['pass']);
$q=mysql_query("SELECT * FROM profiles WHERE username='{$_POST['login']}' AND password='{$_POST['pass']}'",$db) or die(mysql_error());
/*If there is a matching row*/
if(mysql_num_rows($q) > 0)
{
$_SESSION['login'] = $_POST['login'];
$login='Welcome back, '.$_SESSION['login'];
$login.='</br> we are redirecting you.';
echo $login;
echo '<META HTTP-EQUIV="Refresh" Content="2; URL=/php/learn/selectone.php">';
exit;
}
else
{
$login= 'Wrong login or password';
}
mysql_close($db);
}
//you may echo the data anywhere in the file
echo $login;
?>
$_SESSION['var']; を使用して、他のすべてのファイルでログインとパスワードを使用できます。残りはどうやって手に入れるの?彼らの年齢は好きですか?または彼らの名前?または私のmysqlファイルに保存されている変数。はい、私は MD5 が最善ではないことを知っています。これをその議論に変えないようにしましょう。
- - - - - - - - - - - - 編集 - - - - - - - - - - - - - ------ 私はそれを言い換えると思います:
私はこれを使用します:
$q=mysql_query("SELECT * FROM profiles WHERE username='{$_POST['login']}' AND password='{$_POST['pass']}'",$db) or die(mysql_error());
その特定のユーザー/プロファイルから変数を取得するにはどうすればよいですか? 私のmysqlではfnameである名前など、他の変数と同様に。
- - - - - - - - - - - - -編集 - - - - - - - - - - - - --- 次のように更新しました。
$mysqli = new mysqli('localhost', 'teachert_users', 'dogs1324', 'teachert_users');
if($mysqli->connect_errno) {
echo "Error connecting to MySQL: (" . $mysqli->connect_errno . ") " . $mysqli->connect_error;
}
$user = $_SESSION['login'];
$get_user_info_query = $mysqli->query("SELECT * FROM profiles WHERE username = '$user'");
if($get_user_info_query->num_rows) {
while($get_user_info_row = $get_user_info_query->fetch_assoc()){
if ($get_user_info_row['math']) {
print_r($get_user_info_row['math']);
}
}
} else {
echo 'User not found';
}
ただし、print_r はすべてのユーザー情報を出力します。数学情報だけではありません。なんで?