gpt4 book ai didi

php - 如何通过表单提交更新 php 文件中的变量?比如静态密码

转载 作者:搜寻专家 更新时间:2023-10-31 21:38:50 25 4
gpt4 key购买 nike

作为 PHP 的新手,我进行了大量研究,但找不到这个问题的答案。为了提供一些细节,我有一个使用 PHP 和 Javascript 的小型上传网络应用程序。在我所说的受用户名和密码保护的管理部分中,用户可以访问上传的文件。

此时我在 php 文件中设置静态用户名和密码并将它们存储为以下变量。

$username = "admin";
$password ="admin";

登录页面然后读取表单帖子以验证输入的用户名和密码是否与设置的匹配。一旦通过身份验证,它就会设置一个 session token 。这一切都很好,但我希望人们能够在 admin.php 部分中更改密码。

所以我想在 admin.php 上有一个更改密码表单,当有人提交它时,它会更新 login.php 文件中的 $password 变量。如何写入现有的 login.php 文件并更新静态变量 $password。

如有任何帮助,我们将不胜感激!

更新:我当前的 login.php 文件

正如您所见,用户名和密码是静态设置的,一旦有人输入登录信息并验证它是否设置了 session 变量。我想要一种方法让 admin.php 页面上的人能够提交表单来更新 $password 变量。我现在正在阅读这篇文章change admin password (need to make form)

<?php //Password Protected Area
session_start();
if($_GET['action'] == 'logout'){
unset($_SESSION['currentUser']);
}

$requestMethod = strtolower($_SERVER['REQUEST_METHOD']);
if($requestMethod == 'post'){
$username = "admin";
$password ="admin";
$postUsername = strip_tags($_POST['username']);
$postPassword = strip_tags($_POST['password']);
if(($postUsername == $username) && ($postPassword == $password)){
$_SESSION['currentUser'] = 'admin';
header("location: admin.php");
}else{
$loginError = true;
}
}

?>

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8" />
<title>Login</title>

<?php include_once "assets/includes/loader.php" ?>

</head>
<body>

<div id="wrapper">

<div id="upload-text" >
<h1>Please Login</h1>


<form action="<?php echo $_SERVER['PHP_SELF'];?>" method="POST" id="loginForm">

<?php if($loginError){?>
<h2>Login Error:</h2>
<p>Sorry, your username or password was incorrect.</p>
<?php } ?>
<br>
<label><span>Username:</span> <input type="text" name="username" value="<?php echo $_POST['username'];?>" /></label>
<br>
<br>
<label><span>Password:</span> <input type="password" name="password" /></label>
<br><br>
<label><input type="submit" value="Login" /></label>
</form>

</div>

</div>
<!-- #upload-wrapper -->

</body>
</html>

更新:

我根据提供的建议进行了工作,并使其正常运行。请参阅下面的更新代码。我创建了一个 config.php 文件并在那里存储了登录信息。使用 login.php 文件的包含,我正在调用信息。一旦通过身份验证,admin.php 文件就有一个使用和 fwrite 更新 conif.php 文件的表单。

登录.php

$requestMethod = strtolower($_SERVER['REQUEST_METHOD']);
if($requestMethod == 'post'){
include "assets/includes/config.php";
$postUsername = strip_tags($_POST['username']);
$postPassword = strip_tags($_POST['password']);
if(($postUsername == $username) && ($postPassword == $password)){
$_SESSION['currentUser'] = 'admin';
header("location: admin.php");
}else{
$loginError = true;
}
}

管理员.php

if(isset($_POST['new_pw']) && trim($_POST['new_pw']) != ""){
$fp = fopen("assets/includes/config.php", 'w');
fwrite($fp, '<?php');
fwrite($fp, ' ');
fwrite($fp, '$username = "admin";');
fwrite($fp, '$password = "'.trim($_POST['new_pw']).'";');
fwrite($fp, ' ');
fwrite($fp, '?>');
fclose($fp);
}
?>

<form method="post" action="<?php $_SERVER['PHP_SELF'] ?>">
<input type="text" name="new_pw">
<input type="submit">
</form>

最佳答案

更新的答案:

创建一个配置文件并将其放在网络根目录后面。内容是:

<?php
$username = 'admin';
$password = 'admin;

然后包含嵌套的配置文件并从您的 $requestMethod 条件中删除 $username$password 声明:

<?php //Password Protected Area
session_start();

if($_GET['action'] == 'logout'){
unset($_SESSION['currentUser']);
}

$requestMethod = strtolower($_SERVER['REQUEST_METHOD']);
if($requestMethod == 'post'){
include($_SERVER['DOCUMENT_ROOT']."/path-to-nested-config.php");
$postUsername = strip_tags($_POST['username']);
$postPassword = strip_tags($_POST['password']);
if(($postUsername == $username) && ($postPassword == $password)){
$_SESSION['currentUser'] = 'admin';
header("location: admin.php");
}else{
$loginError = true;
}
}
?>

最后,要更新您将使用的文件 fwrite

<?php
if(isset($_POST['new_pw']) && trim($_POST['new_pw']) != "")
{
$fp = fopen($_SERVER['DOCUMENT_ROOT']."/path-to-nested-config.php", 'w');
fwrite($fp, '<?php');
fwrite($fp, '$username = "admin"');
fwrite($fp, '$password = "'.trim($_POST['new_pw']).'");
fclose($fp);
}
?>

这假设您在某个地方有一个表单,该表单将“new_pw”传递给一个 php 脚本,该脚本写入一个配置文件,并设置了由系统写入的适当权限。

这只是一种方法。我选择这样做是因为配置文件只有 3 行代码,所以不需要更高级的系统。

关于php - 如何通过表单提交更新 php 文件中的变量?比如静态密码,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13462072/

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