- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
作为 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/
这个问题在这里已经有了答案: 关闭 10 年前。 Possible Duplicate: How to nest OR statements in JavaScript? 有没有办法做到这一点:
在 JavaScript 中有没有办法让一个变量总是等于一个变量?喜欢var1 = var2但是当var2更新,也是var1 . 例子 var var1 = document.getElementBy
我正在努力理解这代表什么 var1 = var2 == var3 我的猜测是这等同于: if (var2 == var3): var1 = var2 最佳答案 赋值 var1 = var2
这个问题已经有答案了: What does the PHP error message "Notice: Use of undefined constant" mean? (2 个回答) 已关闭 8
我在临时表中有几条记录,我想从每条记录中获取一个值并将其添加到一个变量中,例如 color | caption -------------------------------- re
如何将字符串转为变量(字符串变量--> $variable)? 或者用逗号分隔的变量列表然后转换为实际变量。 我有 2 个文件: 列名文件 行文件 我需要根据字符串匹配行文件中的整行,并根据列名文件命
我有一个我无法解决的基本 php 问题,我也想了解为什么! $upperValueCB = 10; $passNodeMatrixSource = 'CB'; $topValue= '$uppe
这可能吗? php $variable = $variable1 || $variable2? 如果 $variable1 为空则使用 $variable2 是否存在类似的东西? 最佳答案 PHP 5
在 Perl 5.20 中,for 循环似乎能够修改模块作用域的变量,但不能修改父作用域中的词法变量。 #!/usr/bin/env perl use strict; use warnings; ou
为什么这不起作用: var variable; variable = variable.concat(variable2); $('#lunk').append(variable) 我无法弄清楚这一点
根据我的理解,在32位机器上,指针的sizeof是32位(4字节),而在64位机器上,它是8字节。无论它们指向什么数据类型,它们都有固定的大小。我的计算机在 64 位上运行,但是当我打印包含 * 的大
例如: int a = 10; a += 1.5; 这运行得很完美,但是 a = a+1.5; 此作业表示类型不匹配:无法从 double 转换为 int。所以我的问题是:+= 运算符 和= 运算符
您好,我写了这个 MySQL 存储过程,但我一直收到这个语法错误 #1064 - You have an error in your SQL syntax; check the manual that
我试图在我的场景中显示特定的奖牌,这取决于你的高分是基于关卡的目标。 // Get Medal Colour if levelHighscore goalScore { sc
我必须维护相当古老的 Visual C++ 源代码的大型代码库。我发现代码如下: bIsOk = !!m_ptr->isOpen(some Parameters) bIsOk的数据类型是bool,is
我有一个从 MySQL 数据库中提取的动态产品列表。在 list 上有一个立即联系 按钮,我正在使用一个 jquery Modal 脚本,它会弹出一个表单。 我的问题是尝试将产品信息变量传递给该弹出窗
这个问题在这里已经有了答案: 关闭 10 年前。 Possible Duplicate: What is the difference between (type)value and type(va
jQuery Core Style Guidelines建议两种不同的方法来检查变量是否已定义。 全局变量:typeof variable === "undefined" 局部变量:variable
这个问题已经有答案了: 已关闭11 年前。 Possible Duplicate: “Variable” Variables in Javascript? 我想肯定有一种方法可以在 JavaScrip
在语句中使用多重赋值有什么优点或缺点吗?在简单的例子中 var1 = var2 = true; 赋值是从右到左的(我相信 C# 中的所有赋值都是如此,而且可能是 Java,尽管我没有检查后者)。但是,
我是一名优秀的程序员,十分优秀!