-1

シングルページアプリを作成しようとしています。ログインに成功すると、ログアウトへのリンクを含む成功ページ (login_success.php) が表示されます。ログアウト リンクをクリックすると、「メイン」div が空になり、logout.php (「ログアウトしました」ページ) が「メイン」div に挿入されます。ただし、ログアウト リンクをクリックしても何も起こりません。js/application.js

$(document).ready(function() {
    $("#logoutlinkdiv a").click(function(event) {
        event.preventDefault();
        $("#main").empty();
        $("#main").load("templates/logout.php");
        alert("working");
   });
});

アラートは決して実行されません...

テンプレート/login_success.php

<?php
session_start();

if($_SESSION['username'] === null){
header("location: ../index.php");
}
?>

<!DOCTYPE html>
<html>
<body>
<h1>Login Successful</h1>
<h2>Username: <? echo $_SESSION['username']?></h2>
<div id="logoutlinkdiv">
<a href = "#">Log out</a>
</div>
</body>
</html>

index.php

<!DOCTYPE html>
<html>
<head>
<title>it IT</title>
<script src="reqscripts/jquery.js"></script>
<script src="js/application.js"></script>
</head>
<body>
<form id="login" method="post" action="checklogin.php">
    <h1>Member Login</h1>
    <p>Username:<input name="myusername" type="text" id="myusername"></p>
    <p>Password:<input name="mypassword" type="password" id="mypassword"></p>
    <input type="submit" name="Submit" value="Login">
</form>
<div id="main"></div>
</body>
</html>

checklogin.php

<?php

session_start();

$host="localhost"; // Host name
$username="root"; // Mysql username
$password="bonjour3"; // Mysql password
$db_name="itit"; // Database name
$tbl_name="members"; // Table name

// Connect to server and select databse.
$mysqli = new mysqli("$host", "$username", "$password", "$db_name")or die("cannot connect");

// Define $myusername and $mypassword
$myusername=$_POST['myusername'];
$mypassword=$_POST['mypassword'];

$sql = $mysqli->prepare("SELECT * FROM $tbl_name WHERE username=? and password=?");
$sql->bind_param('ss',$myusername,$mypassword);
$sql->execute();
$sql->store_result();//apply to prepare statement
$numRows = $sql->num_rows;

if($numRows === 1){
    $_SESSION['username'] = $myusername;
}
else {
    echo "Wrong Username or Password";
    session_destroy();
}
?>
4

4 に答える 4

0

login_success.php は別の静的ページであるため、リダイレクト時に jQuery ファイルが必要です。

于 2013-11-25T15:20:18.490 に答える
0

内部にイベントを追加function(event)します。それ以外の場合、デフォルトの href="#" が実行されます。

  $("#logoutlinkdiv a").click(function(event) {
            event.preventDefault();
            ....
    }
于 2013-06-15T17:48:28.213 に答える