gpt4 book ai didi

php - 无法更新用户名值。 PHP/MySQL

转载 作者:行者123 更新时间:2023-11-29 13:53:25 25 4
gpt4 key购买 nike

我遇到以下问题。当我尝试通过 HTML 表单更新用户名值时。这是我的 HTML 表单:

<form action="namechanging.php" method="post">

<br>
<fieldset>
<span class="ico user-ico"></span>
<input name="ingamename" type="text" class="field" value="Example: John_Doe" title="Example: John_Doe" />
</fieldset>
<center><input name="submit" type="submit" class="submit btn blue-btn" value="Change Name" /></center>
</form>

这是我的 namechanging.php 文件:

<?php 
session_start();
$_SESSION['ingamename'] = $_POST['ingamename'];
$newingamename = $_SESSION['ingamename'];
$nc = $_SESSION['nc'];
if($nc < 1){
$updateresult = '<strong>Error:</strong> You do not have any name changes left. Donate for more...';
header("Location: ucp-home-error.php");
}
else {
$con=mysqli_connect("localhost","USERNAME","PASS","DB-NAME");
if (mysqli_connect_errno())
{
echo "Failed to connect to MySQL: " . mysqli_connect_error();
}
$newnc = $nc - 1;

mysqli_query($con,"UPDATE users SET Username=$newingamename WHERE Username='$_SESSION[user]' ");
mysqli_query($con,"UPDATE users SET NameChanges=$newnc
WHERE Username='$_SESSION[user]'");
$updateresult = 'Your In-Game Name was changed successfully. Please re-log!';
header("Location: ucp-home-success.php");
}
mysqli_close($con);
$_SESSION['updateresult'] = $updateresult;?>

它可以从 $nc 中删除 -1,但不会更改用户名。您还应该知道用户名保存在 session 中,这是我登录身份验证页面时使用的用户名。这是我的 auth.php 文件:

<?php
include("sql.php");
session_start();

function Destroy() {
unset($_SESSION['UID']);
unset($_SESSION['USERNAME']);
unset($_SESSION['FULL NAME']);
header("location: account-log-in-restricted.php");
}

if(isset($_SESSION['UID']) && isset($_SESSION['USERNAME'])) {
$UID = $_SESSION['UID'];
$username = $_SESSION['USERNAME'];
$qry = mysql_query("SELECT * FROM `users` WHERE `UID` = '$UID' AND `Username` = '$username'");
if(mysql_num_rows($qry) != 1) { Destroy(); }
} else { Destroy(); }
?>

最佳答案

它可能会被这个窒息:

mysqli_query($con,"UPDATE users WHERE Username='$_SESSION[user]' SET Username=$newingamename");
1 ^^^^^^^^^^^^^ 2 ^^^^^^^^^^^^

在 (1) 中,这相当于 $_SESSION[user]当你想要的是$_SESSION['user']时(带 user 周围的引号)。

在 (2) 中,您需要在 $newingamename 两边加上单引号。

注意:其余部分是根据原始答案进行编辑的,目的是 (a) 合并 PHP 和 MySQL 修复,以及 (b) 使用 mysqli 进行重铸。用于代码安全的参数绑定(bind)。

此外,MySQL 查询错误:SET出现在 WHERE 之前.

将这些放在一起,使用 mysqli代码(和职业)安全性的绑定(bind)参数,你会得到:

$stmt = mysqli_prepare($con, 'UPDATE users SET username=? WHERE username = ?');
mysqli_stmt_bind_param($stmt, 'ss', $newingamename, $_SESSION['user']);
mysqli_stmt_execute($stmt);

对其他 UPDATE 进行类似的更改.

关于php - 无法更新用户名值。 PHP/MySQL,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16305832/

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