gpt4 book ai didi

PHP 退出

转载 作者:行者123 更新时间:2023-12-04 06:32:01 29 4
gpt4 key购买 nike

我在 Lynda.com 上学习 PHP 2 视频时遇到了一个问题,因为讲师似乎忽略了告诉我们他在视频中执行的步骤之一。我在这里上传了相关视频http://www.youtube.com/watch?v=fFKgAa7RAjo但也会描述问题。在视频的 6:40,登录我们的应用程序后,他到达了 public/admin/index.php,上面有两个链接。一个链接允许他“查看日志文件”,将他带到 public/admin/logfile.php 和另一个链接允许他注销。他没有告诉我们如何建立这些链接。我显然可以创建一个链接来查看日志文件

 <a href="logfile.php">View Logfile</a>

但我不知道如何制作将我注销的链接,因为这显然会涉及到一些 PHP。

我在 login.php 文件下面包含了 index.php 文件(登录后重定向到 index.php)和 functions.php 文件。你知道我将如何退出吗?

这是 login.php 文件
<?php

require_once("../../includes/initialize.php");

if($session->is_logged_in()){
redirect_to("index.php");
}

//Remember to give your form's submit tag a name="submit" attribute
if (isset($_POST['submit'])) {//Form has been submitted.

$username = trim($_POST['username']);
$password = trim($_POST['password']);

//Check database to see if username/password exist

$found_user = User::authenticate($username, $password);

if ($found_user) {
$session->login($found_user);
log_action('Login', "{$found_user->username} logged in.");
redirect_to("index.php");
} else {
//username/password combo was not found in the database
$message = "Username/password combination incorrect.";
}
} else {//Form has not been submitted.
$username = "";
$password = "";
}
?>

<?php include_layout_template('admin_header.php'); ?>

<h2>Staff Login</h2>
<?php echo output_message($message); ?>

<form action="login.php" method="post">
<table>
<tr>
<td>Username:</td>
<td>
<input type="text" name="username" maxlength="30" value="<?php
echo htmlentities($username); ?>" />
</td>
</tr>
<tr>
<td>Password:</td>
<td>
<input type="password" name="password" maxlength="30" value="<?php
echo htmlentities($password); ?>" />
</td>
</tr>
<tr>
<td colspan="2">
<input type="submit" name="submit" value="login" />
</td>
</tr>
</table>
</form>
</div>
<?php include_layout_template('admin_footer.php'); ?>

函数.php
<?php

function strip_zeros_from_date( $marked_string=""){
//first remove the marked zeros
$no_zeros = str_replace('*0', '', $marked_string);
//then remove any remaining marks
$cleaned_string = str_replace('*', '', $no_zeros);
return $cleaned_string;

}

function redirect_to( $location= NULL) {
if($location != NULL) {
header("Location: {$location}");
exit;
}

}

function output_message($message=""){
if (!empty($message)) {
return "<p class=\"message\">{$message}</p>";
} else {
return "";
}
}

function __autoload($class_name) {
$class_name = strtolower($class_name);
$path = LIB_PATH.DS."{$class_name}.php";
if(file_exists($path)){
require_once($path);
} else {
die("The file {$class_name}.php could not be found.");
}
}

function include_layout_template($template=""){
include(SITE_ROOT.DS.'public'.DS.'layouts'.DS.$template);
}

function log_action($action, $message=""){
$logfile = SITE_ROOT.DS.'logs'.DS.'log.txt';
$new = file_exists($logfile) ? false : true;
if($handle = fopen($logfile, 'a')) { //apppend
$timestamp = strftime("%Y-%m-%d %H:%M:%S", time());
$content = "{$timestamp} | {$action}: {$message}\n";
fwrite($handle,$content);
fclose($handle);
if($new) {chmod($logfile, 0755); }
} else {
echo "Could not open log file for writing.";
}
}

?>

索引.php
<?php

require_once('../../includes/initialize.php');

if (!$session->is_logged_in()) { redirect_to("login.php"); }
?>

<?php include_layout_template('admin_header.php'); ?>

<h2>Menu</h2>

</div>


<?php include_layout_template('admin_footer.php'); ?>

更新

初始化.php
<?php

//Directory_separator is a PHP pre-defined constant
// (\ for windows, / for Unix)

defined('DS') ? null : define('DS', DIRECTORY_SEPARATOR);

defined('SITE_ROOT') ? null :
define('SITE_ROOT', DS.'hsphere'.DS.'local'.DS.'home'.DS.'c263430'.DS.'quoralist.com');
// define('SITE_ROOT', realpath(dirname(__FILE__).'/../'));

//echo SITE_ROOT."<br/>";

defined('LIB_PATH') ? null : define('LIB_PATH', SITE_ROOT.DS.'includes');
// die(LIB_PATH);

//echo LIB_PATH."<br/>";

require_once(LIB_PATH.DS."config.php");
require_once(LIB_PATH.DS."functions.php");
require_once(LIB_PATH.DS."session.php");
require_once(LIB_PATH.DS."database.php");
require_once(LIB_PATH.DS."database_object.php");
require_once(LIB_PATH.DS."user.php");

//echo("You die here");

?>

用户名
<?php

require_once(LIB_PATH.DS.'database.php');

class User extends DatabaseObject{

protected static $table_name="users";
public $id;
public $username;
public $password;
public $first_name;
public $last_name;

public function full_name() {
if(isset($this->first_name) && isset($this->last_name)) {
return $this->first_name . " " . $this->last_name;
} else {
return "";
}
}

public static function authenticate($username="",$password="") {
global $database;
$username = $database->escape_value($username);
$password = $database->escape_value($password);
$sql = "SELECT * FROM users ";
$sql .= "WHERE username = '{$username}' ";
$sql .= "AND password = '{$password}' ";
$sql .= "LIMIT 1";
$result_array = self::find_by_sql($sql);
return !empty($result_array) ? array_shift($result_array) : false;

}

//common database methods

public static function find_all(){
return self::find_by_sql("SELECT * FROM ".self::$table_name);

}

public static function find_by_id($id=0) {
global $database;
$result_array = self::find_by_sql("SELECT * FROM ".self::$table_name." WHERE id={$id} LIMIT 1");
return !empty($result_array) ? array_shift($result_array) : false;
}

public static function find_by_sql($sql=""){
global $database;
$result_set = $database->query($sql);
$object_array = array();
while ($row = $database->fetch_array($result_set)) {
$object_array[] = self::instantiate($row);
}
return $object_array;
}




private static function instantiate($record){

$object = new self;
//$object->id = $record['id'];
//$object->username = $record['username'];
//$object->password = $record['password'];
//$object->first_name = $record['first_name'];
//$object->last_name = $record['last_name'];

foreach($record as $attribute=>$value) {
if($object->has_attribute($attribute)) {
$object->$attribute = $value;
}
}
return $object;
}

private function has_attribute($attribute) {
$object_vars = get_object_vars($this);
return array_key_exists($attribute, $object_vars);
}

}




?>

session 文件
<?php


class Session {

private $logged_in=false;
public $user_id;

function __construct() {
session_start();
$this->check_login();
if($this->logged_in){
//actions to take right away if user is logged in
} else {
//actions to take right away if user is not logged in
}
}

public function is_logged_in() {
return $this->logged_in;
}

public function login($user) {
//database should find user based on username/password
if($user){
$this->user_id = $_SESSION['user_id'] = $user->id;
$this->logged_in = true;
}
}

public function logout(){
unset($_SESSION['user_id']);
unset($this->user_id);
$this->logged_in = false;
}

private function check_login(){
if(isset($_SESSION['user_id'])){
$this->user_id = $_SESSION['user_id'];
$this->logged_in = true;
} else {
unset($this->user_id);
$this->logged_in = false;
}
}
}

$session = new Session();

?>

最佳答案

 <?php
session_start();
session_destroy();
?>

这应该销毁存储在 session 中的所有变量。注销真的很原始,但它应该可以工作。完成后,只需重定向到“index.php”或您想要的任何页面。

关于PHP 退出,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5279882/

29 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com