PHP登入跳轉
session_start();
include("config.php");//串連資料庫
$username=$_POST['user'];
$word=$_POST['password'];
$userword=md5(trim($word));//MD5轉換密碼
$id=$_POST['user_id'];
if($id=="student")
{
$result_psword=mysql_query("select S_PS from STUDENT where S_ID='$username'");
/*while ($rows=mysql_fetch_array($result_psword)){}*/
if(!$result_psword)
{
echo "使用者不存在,請先註冊";
echo "";
exit;
}
else if($result_psword==$userword)
{
$_SESSION['login']='學生';
echo "";
}
}
登入後發現沒有跳轉,直接停在login.php頁面裡。
$username,$userword,$id都測試了有傳進去值,我想就是
$result_psword=mysql_query("select S_PS from STUDENT where S_ID='$username'");
這句的問題了。
$reslt_psword我想測試裡面的值都測試不出來,這個裡面到底包含著什麼東西?
($result_psword==$userword)這句話直接判斷為什麼會不行?
做畢設中,分不敢給多啊··留點以後用。
------解決方案--------------------
PHP code
------解決方案--------------------
mysql_query()返回的是資源集。因此不能那麼判斷。
if(!$result_psword)
{
echo "使用者不存在,請先註冊";
echo "";
exit;
}
==》改為:
if(!mysql_num_rows($result_psword))
{
echo "使用者不存在,請先註冊";
echo "";
exit;
}
------解決方案--------------------
http://dev.mysql.com/doc/refman/5.1/zh/index.html
------解決方案--------------------
判斷邏輯寫反了
你的
if(!$_SESSION['login']||$_SESSION['login']!='管理員'||$_SESSION['login']!='教師'||$_SESSION['login']!='學生')
表示只要有有一個成立就進入
但是,比如當 $_SESSION['login'] = '管理員' 時,
$_SESSION['login']!='教師' 和 $_SESSION['login']!='學生'
都會成立的
應寫作
if(!$_SESSION['login'] || ($_SESSION['login']!='管理員' && $_SESSION['login']!='教師' && $_SESSION['login']!='學生'))