gpt4 book ai didi

php - session_start() 导致问题

转载 作者:行者123 更新时间:2023-11-29 20:58:21 27 4
gpt4 key购买 nike

我的代码有问题。这是我按照教程制作的登录/注册脚本。

我遇到的问题是,我希望脚本仅在用户输入正确的登录详细信息时回显“已登录”,但即使我没有输入任何登录详细信息,它仍然会回显“已登录”。我检查了它,如果我删除“session_start()”函数,它不会做同样的事情,但当我想登录时它仍然不允许我访问 session 。

这是init.php文件,用于发起与数据库的连接并定义一些其他函数:

<?php  
session_start();
require 'database/connect.php';
require 'functions/general.php';
require 'functions/users.php';

$errors = array();
?>

这是connect.php文件,用于连接数据库:

<?php 
$connect_error = 'Sorry, we are experiencing connection issues. This will be solved as soon as possible.';
$con=mysqli_connect("localhost","root","","lr") or die ($connect_error);

mysqli_select_db($con,'lr') or die($connect_error);



mysqli_close($con);

?>

general.php 文件对于这个问题并不重要。这是 users.php 文件,我在其中保存了一些其他函数。

function user_id_from_username ($username){
$username = sanitise($username);
$mysqli = new mysqli("localhost", "root", "", "lr");
$query = "SELECT * FROM users";
$result = $mysqli->query($query);
while($row=$result->fetch_row()){
if ($row[1]==$username){ //username == $username
return $row[0];//user_id;
}
}
}



function login ($username, $password){
$user_id= user_id_from_username($username);
$mysqli = new mysqli("localhost", "root", "", "lr");
$username = sanitise($username);
$password =md5 ($password);

$query = "SELECT * FROM users";

$result = $mysqli -> query($query);

while ($row =$result -> fetch_row()){
if($row[1]==$username && $row[2]==$password){
return TRUE;
}else {
return FALSE;
}

}

}

这是调用登录函数的文件,如上面所示:

<?php 
include 'core/init.php';




if (empty($_POST) === false) {

$username = $_POST['username'];
$password = $_POST['password'];

if (empty($username) ===TRUE || empty ($password) === TRUE) {
$errors[]='You need to enter a username and password!';
} else if (user_exists($username) ===FALSE) {
$errors[]="We can't find that username, have you registered?";
} else if (user_active($username)===FALSE){
$errors[]="You have not activated your account!";
} else{
$login = login($username, $password);
session_start();
if ($login ==false) {
$errors[] ='That username/password combination is incorrect!';
}else if ($login==true) {
//set the user session
$_SESSION['username'] = $login;

//redirect user to homepage
header('Location: index.php');
exit();
}

}


if ($errors){
print_r($errors);
}

}
?>

现在是index.php 文件,其中有 if 语句,即使我没有登录,也会回显“已登录”:

<?php 

if (empty($_SESSION['username'])) {
echo 'not logged_in';

}else {
echo 'logged in';

}

?>

现在我认为问题出在users.php、login.php 或index.php 文件中的某个位置。我展示了所有文件,以便您可以了解我想要实现的目标。该代码分布在如此多的文件中,因为我有包含的函数和接口(interface),并且我希望能够重用这些代码,所以我使用包含。

为了让您获得更好的想法,如果我的文件对您的帮助不够,我将留下我正在关注的教程的 Youtube 链接: https://www.youtube.com/watch?v=JUk2e8oqOvI&list=PLE134D877783367C7&index=7#t=6.296979

谢谢,

等待您的答复,

最诚挚的问候,

最佳答案

如果您不使用 $_GET 请求来包含页面,则需要将 session_start() 放在使用 >$_SESSION 变量,否则您无法使用 session 。

<?php
session_start();
// Rest of your script

希望这对您有帮助。

关于php - session_start() 导致问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37437038/

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