所以,正如标题所说,我需要一些关于如何进行交互 jquery、ajax 和 php 的说明,以实现表单提交和其他控件。
这是我第一次将 jquery、ajax 和 php 一起使用的网络体验,当然,我也遇到了一些问题。
我描述了我正在尝试做的事情。
基本上,我有一个带有注册表单的索引页:
<form id="formRegistration" action="registration_success.php" method="post">
<p id="ptxtFullName">
<input id="txtFullName" name="txtFullName" class="textbox" placeholder="Insert you full name" type="text" />
</p>
<p id="pTxtEmail">
<input id="txtEmail" name="txtEmail" class="textbox" placeholder="Insert an email" type="text" />
</p>
<p id="pTxtPassword">
<input id="txtPassword" name="txtPassword" class="textbox" placeholder="Choose a password" type="password" />
</p>
<p id="pTxtPasswordConfirmation">
<input id="txtPasswordConfirmation" name="txtPasswordConfirmation" class="textbox" placeholder="Confirm your password" type="password" />
</p>
<p id="pBtnRegistration">
<input id="btnRegistration" type="submit" value="Register!" />
</p>
</form>
然后,我有一个 jquery 文件,它执行所有输入验证的事情(如果输入正确或不正确,会产生一些影响,以及类似的事情),并且,如果验证顺利,则进行 ajax 调用。这只是一个示例,我不会发布整个文件,因为它非常庞大:
jQuery(document).ready(function($) {
$(function() {
var $fullName = $("input[name='txtFullName']");
var $email = $("input[name='txtEmail']");
var $password = $("input[name='txtPassword']");
var $passwordConfirmation = $("input[name='txtPasswordConfirmation']");
$("#btnRegistration").click(function() {
//Validation controls and effects.
});
return true;
});
$.ajax({
type : "POST",
url : "process_registration.php",
data : "fullName", "email", "password",
dataType : "HTML",
success : function() {
alert("Ok");
},
error : function() {
alert("Error");
}
});
});
请注意,jquery 文件,当我添加 ajax 调用时,它会停止工作,而如果我不添加 ajax 调用,它会完美运行。
然后,这是我的 php 文件,名为 process_registration.php,它应该控制电子邮件是否已在使用中,然后将经过验证的输入数据插入 MySQL 数据库:
<?php
需要'db_connection.php';
$fullName = isset($_POST["fullName"]);
$email = isset($_POST["email"]);
$password = isset($_POST['password']);
$sql = mysql_query("SELECT * FROM utente WHERE mail = '$email'") or die("Email already in use");
$num_rows = mysql_num_rows($sql);
if ($num_rows == 0)
{
$password_md5 = md5($password);
mysql_query("INSERT INTO user (Full_Name , Email, Password) VALUES
('$fullName', '$email', '$password_md5')") OR DIE(mysql_error());
}
就这样。
显然它不起作用。
也许我在这件事上采用了完全错误的方法?
提前感谢您的好意和您的回答。