我开始为我的应用程序使用PHP登录脚本的基本启动,从here克隆。当试图在注册页面上添加元素时,signup.php数据在经过AJAX处理后不会传递给PHP。我非常熟悉PHP,AJAX是一个不同的故事-我是一个新手。
我添加了一个POST解析器来输出到主注册页面,看看PHP接收到了什么。除了我添加的那个,所有其他输入都被接收到了。如错误所示:
第一个月
x1c 0d1x的数据
正如你在这里看到的,POST结果显示在弹出窗口的下面,我想看看POST到PHP user.php的是什么。很明显,我添加的name元素没有被路由到正确的PHP文件。当然,PHP显示的错误解释说,由于它没有被POST,所以找不到name。
signup.php,添加的行是<input name="name" id="name" type="text" class="form-control" placeholder="John Smith" autofocus>
。在文件的最后我添加了一个验证,以确保表单在发布到signup.js之前已经填写完毕。我不相信这个问题是在这个php文件上。
if (isset($_SESSION['username'])) {
session_start();
session_destroy();
}
?>
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>Signup</title>
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<!-- Bootstrap -->
<link href="../css/bootstrap.css" rel="stylesheet" media="screen">
<link href="../css/main.css" rel="stylesheet" media="screen">
</head>
<body>
<div class="container">
<form class="form-signup" id="usersignup" name="usersignup" method="post" action="createuser.php">
<h2 class="form-signup-heading">Register</h2>
<input name="newuser" id="newuser" type="text" class="form-control" placeholder="Username" autofocus>
<input name="name" id="name" type="text" class="form-control" placeholder="John Smith" autofocus>
<input name="email" id="email" type="text" class="form-control" placeholder="Email">
<br>
<input name="password1" id="password1" type="password" class="form-control" placeholder="Password">
<input name="password2" id="password2" type="password" class="form-control" placeholder="Repeat Password">
<button name="Submit" id="submit" class="btn btn-lg btn-primary btn-block" type="submit">Sign up</button>
<div id="message"></div>
</form>
</div> <!-- /container -->
<!-- jQuery (necessary for Bootstrap's JavaScript plugins) -->
<script src="//code.jquery.com/jquery.js"></script>
<!-- Include all compiled plugins (below), or include individual files as needed -->
<script type="text/javascript" src="js/bootstrap.js"></script>
<script src="js/signup.js"></script>
<script src="http://jqueryvalidation.org/files/dist/jquery.validate.min.js"></script>
<script src="http://jqueryvalidation.org/files/dist/additional-methods.min.js"></script>
<script>
$( "#usersignup" ).validate({
rules: {
name: {
required: true
},
email: {
email: true,
required: true
},
password1: {
required: true,
minlength: 4
},
password2: {
equalTo: "#password1"
}
}
});
</script>
</body>
</html>
字符串
signup.js,**这就是我认为问题所在。**很可能是因为我不懂AJAX。这里我唯一改变的是IF语句中的子句和数据对象&name="+name
的结尾。即使在将此添加到post-configureuser.php之后,PHP也不会接收该变量。
$(document).ready(function(){
$("#submit").click(function(){
var username = $("#newuser").val();
var name = $("#name").val();
var password = $("#password1").val();
var password2 = $("#password2").val();
var email = $("#email").val();
if((username == "") || (name == "") || (password == "") || (email == "")) {
$("#message").html("<div class=\"alert alert-danger alert-dismissable\"><button type=\"button\" class=\"close\" data-dismiss=\"alert\" aria-hidden=\"true\">×</button>Please ensure that name, username and password are all filled.</div>");
}
else {
$.ajax({
type: "POST",
url: "createuser.php",
data: "newuser="+username+&password1="+password+"&password2="+password2+"&email="+email+"&name="+name,
success: function(html){
var text = $(html).text();
//Pulls hidden div that includes "true" in the success response
var response = text.substr(text.length - 4);
if(response == "true"){
$("#message").html(html);
$('#submit').hide();
}
else {
$("#message").html(html);
$('#submit').show();
}
},
beforeSend: function()
{
$("#message").html("<p class='text-center'><img src='images/ajax-loader.gif'></p>")
}
});
}
return false;
});
});
型
我不相信这个问题是在这个PHP文件中,但我以前错了。我添加了$name = $_POST['name'];
,我添加了:
foreach ($_POST as $key => $value){
echo "{$key} = {$value}\r\n";
型
<?php
require 'includes/functions.php';
include_once 'config.php';
//Pull username, generate new ID and hash password
$newid = uniqid(rand(), false);
$newuser = $_POST['newuser'];
$newpw = password_hash($_POST['password1'], PASSWORD_DEFAULT);
$pw1 = $_POST['password1'];
$pw2 = $_POST['password2'];
$name = $_POST['name'];
//Enables moderator verification (overrides user self-verification emails)
if (isset($admin_email)) {
$newemail = $admin_email;
} else {
$newemail = $_POST['email'];
}
//Validation rules
if ($pw1 != $pw2) {
echo '<div class="alert alert-danger alert-dismissable"><button type="button" class="close" data-dismiss="alert" aria-hidden="true">×</button>Password fields must match</div><div id="returnVal" style="display:none;">false</div>';
} elseif (strlen($pw1) < 4) {
echo '<div class="alert alert-danger alert-dismissable"><button type="button" class="close" data-dismiss="alert" aria-hidden="true">×</button>Password must be at least 4 characters</div><div id="returnVal" style="display:none;">false</div>';
} elseif (!filter_var($newemail, FILTER_VALIDATE_EMAIL) == true) {
echo '<div class="alert alert-danger alert-dismissable"><button type="button" class="close" data-dismiss="alert" aria-hidden="true">×</button>Must provide a valid email address</div><div id="returnVal" style="display:none;">false</div>';
} else {
//Validation passed
if (isset($_POST['newuser']) && !empty(str_replace(' ', '', $_POST['newuser'])) && isset($_POST['password1']) && !empty(str_replace(' ', '', $_POST['password1']))) {
//Tries inserting into database and add response to variable
$a = new NewUserForm;
$response = $a->createUser($newuser, $newid, $newemail, $newpw);
//Success
if ($response == 'true') {
echo '<div class="alert alert-success"><button type="button" class="close" data-dismiss="alert" aria-hidden="true">×</button>'. $signupthanks .'</div><div id="returnVal" style="display:none;">true</div>';
//Send verification email
$m = new MailSender;
$m->sendMail($newemail, $newuser, $newid, 'Verify');
} else {
//Failure
mySqlErrors($response);
}
} else {
//Validation error from empty form variables
echo 'An error occurred on the form... try again';
}
foreach ($_POST as $key => $value){
echo "{$key} = {$value}\r\n";
}
};
型
为了使它非常清楚,我的问题仍然是为什么我添加的字段没有进入最终的PHP文件。
同样要说明的是,这段代码在没有尝试添加额外字段的情况下运行得很好。经过验证,这段代码是可用的。一旦我尝试添加我的name字段,代码就会中断。
感谢您提供的任何帮助。
2条答案
按热度按时间kuuvgm7e1#
我做了一个虚拟的测试脚本松散的基础上你提供了什么。
提示提供代码时-请指定每个部分的实际文件名。
这是“signup.js”文件的一部分,其中注解掉了数据定义并添加了新定义。
一个更好的方法是如下所示构建数据。
字符串
使用我运行的代码-我将其设置为var_dump($_POST),它将POST数据显示在提交按钮下的表单上。
给予一个机会。
下面是我在表单中输入数据后得到的结果(结果是我为测试而输入的值,我已经删除了您的验证以使其不碍事)
型
2nc8po8w2#
Placeholder不是“默认值”。你不能期望它们作为内容发送。这就是为什么你在PHP中得到警告。
另一个问题是字符串连接:引号丢失。
它应该是
"newuser="+username+"&password1="+password
,而不是你现在拥有的:"newuser="+username+&password1="+password
注意
&password1
之前的引用。您可能应该使用一个更好的编辑器,因为您应该根据语法突出显示来捕捉这一点。
也就是说,这有很多问题。
首先,不要使用
uniqid(rand(), false)
来生成ID,而应该依赖MySQL的AUTO_INCREMENT
功能。然后是JS。你为什么要用jQuery来做这个?!JS现在有Fetch API,这比jQuery的方法要上级。还有FormData抽象,它简化了表单处理。
字符串
不过,您必须添加polyfill以兼容旧版本的IE。
还有.