1

私はPHPを初めて使用し、ログインページで苦労しています。「機能する」次のスクリプトがありますが、他のページに引き継ぐことができるユーザーのパスワードが正しい場合は、セッションを設定したいと思います。だから私はセッションをチェックするためにそれらの他のページに何が必要かを理解しようとしています。

これから、私が戻ってくるページにこのようなものを置くと、次のようになります。

<?php
if($_SESSION['login'] = "1") {  
echo "you are logged in";
}
else
{
echo "you are not logged in";
}
?>

いつも成功のメッセージが届いているようです。私はこれがどのように機能するかを理解してはいけません。どんな提案もありがたいです-必要に応じてこれを完全に書き直してください。ありがとう!

これが私の現在のログインスクリプトです:

<?php
// error reporting
ini_set('display_errors',1); 
 error_reporting(E_ALL);
$host="foo"; // Host name
$username="foo"; // Mysql username
$password="foo"; // Mysql password
$db_name="foo"; // Database name
$tbl_name="members"; // Table name
// Connect to server and select databse.
mysql_connect("$host", "$username", "$password")or die("cannot connect");
mysql_select_db("$db_name")or die("cannot select DB");
// username and password sent from form
$myusername=$_POST['myusername'];
$mypassword=$_POST['mypassword'];
// To protect MySQL injection (more detail about MySQL injection)
$myusername = stripslashes($myusername);
$mypassword = stripslashes($mypassword);
$myusername = mysql_real_escape_string($myusername);
$mypassword = mysql_real_escape_string($mypassword);
$sql="SELECT * FROM $tbl_name WHERE username='$myusername' and password='$mypassword'";
$result=mysql_query($sql);
// Mysql_num_row is counting table row
$count=mysql_num_rows($result);
// If result matched $myusername and $mypassword, table row must be 1 row
if($count==1) {
session_start();
$_SESSION['login'] = "1";
header ("Location: http://www.google.com");
}
else {  
session_start();
$_SESSION['login'] = '';
header ("Location: http://www.yahoo.com");
}
?>

以下に提案されている変更を適用すると、戻ってきたページに次のようになります。

<?php
session_start();
if ($_SESSION['login'] == "1") {  
echo "you are logged in";
}
else if ($_SESSION['login'] == "") 
{
echo "you are not logged in";
}
?>

そして、ログインスクリプトに次の変更を加えました。

if($count==1) {
session_start();
$_SESSION['login'] =="1";
header ("Location: login.php");
}
else {  
session_start();
$_SESSION['login'] == "";
header ("Location: login.php");
}

何があっても、「サインインしていません」というメッセージが表示されます...うーん。

更新--OK--スクリプトに==変更を加えないと、機能するようです。私が持っている場合

if($count==1) {
session_start();
$_SESSION['login'] = "1";
header ("Location: login.php");
}
else {  
session_start();
$_SESSION['login'] = "";
header ("Location: login.php");
} 

そしてこれは私が戻ってきたページで:

<?php
session_start();
if ($_SESSION['login'] == "1") {  
echo "you are logged in";
}
else if ($_SESSION['login'] == "") 
{
echo "you are not logged in";
?>

...それはうまくいくようです。

4

2 に答える 2

2

次のようになります:if($ _SESSION ['login'] == "1")

あなたがそれをしている方法なので、それは値を設定し、trueを返します。

于 2012-11-15T15:35:33.283 に答える
0

変数$myusernameと$mypasswordが2つの異なる関数に指定されているので、それらを個別化することを想定しています......。

于 2013-01-27T10:30:50.940 に答える