当用户登录时,我如何获取他们所有的 mysql 信息?我有一个注册系统和登录系统。当他们登录时,他们输入用户名和密码,这是我唯一可以使用的两个变量,因为他们输入了它们。我如何获取该配置文件的所有其他变量,而不是用户输入的?他们的用户名是独一无二的。我如何让其余的变量在我的所有 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 仍会打印所有用户信息。不仅仅是数学信息。为什么?