JavaScript表单验证,PHP不发送电子邮件
JavaScript form validation with PHP not sending emails
>我有一个联系表单,它对这些字段使用 JavaScript 验证,但是当我将表单链接到我的 PHP 时,它不会发送电子邮件。如果有人能帮助我解决这个问题,将不胜感激。我不太熟悉PHP以及它如何与其他语言交互。
这是一个现场演示。
代码如下:
*编辑*
当前的 JAVASCRIPT:
<script type="text/javascript">
reEmail = /^['w-|+|'|]+('.['w-|+|'|]+)*@([a-zA-Z0-9-]+('.[a-zA-Z0-9-]+)*?'.[a-zA-Z]{2,6}|('d{1,3}'.){3}'d{1,3})(:'d{4})?$/
function myFunction()
{
var y;
y = document.getElementById('name');
var x;
x = document.getElementById('email');
var z;
z = document.getElementById('message');
var e;
e = 0;
if(y.value == "Full Name*"){
alert("Full Name Required");
e = e + 1
return false;
}
if(!(reEmail.test(x.value))){
alert("E-Mail Invalid");
e = e + 1
return false;
}
if(z.value == "Your Message*"){
alert("Please write a message.");
e = e + 1;
return false;
}
if(e < 0){
return false;
} else {
alert("Thank you. Your message has been sent!");
return true;
}
}
</script>
*编辑*
当前网页:
<body>
<div class="form" align="center">
<form onSubmit="myFunction();" name="contact" action="sendform.php" method="post" >
<span style="display:block;">
<input name="name" type="text" id="name" class="txt" maxlength="50" value="Full Name*" onfocus="if(this.value==this.defaultValue)this.value='';" onblur="if(this.value=='')this.value=this.defaultValue;">
</span>
<br />
<span style="display:block">
<input name="email" type="text" id="email" class="txt" maxlength="20" value="Your E-Mail*" onfocus="if(this.value==this.defaultValue)this.value='';" onblur="if(this.value=='')this.value=this.defaultValue;" >
</span>
<br />
<span style="display:block">
<textarea name="message" type="text" id="message" class="txt" maxlength="500" value="Your Message*" onfocus="if(this.value==this.defaultValue)this.value='';" onblur="if(this.value=='')this.value=this.defaultValue;">Your Message*</textarea>
</span>
</form>
<br />
<span id="required">* Indicates Required Fields</span>
<br />
<input type="submit" onclick="myFunction()" class="submit" value="Submit" >
</div>
</body>
PHP(sendform.php):
<?php
if(isset($_POST['email'])) {
// EDIT THE 2 LINES BELOW AS REQUIRED
$email_to = "email@domain.com";
$email_subject = "Your email subject line";
function died($error) {
// your error code can go here
echo "We are very sorry, but there were error(s) found with the form you submitted. ";
echo "These errors appear below.<br /><br />";
echo $error."<br /><br />";
echo "Please go back and fix these errors.<br /><br />";
die();
}
// validation expected data exists
if(!isset($_POST['name']) ||
!isset($_POST['email']) ||
!isset($_POST['message'])) {
died('We are sorry, but there appears to be a problem with the form you submitted.');
}
$first_name = $_POST['name']; // required
$email_from = $_POST['email']; // required
$comments = $_POST['message']; // required
$error_message = "";
$email_exp = '/^[A-Za-z0-9._%-]+@[A-Za-z0-9.-]+'.[A-Za-z]{2,4}$/';
if(!preg_match($email_exp,$email_from)) {
$error_message .= 'The Email Address you entered does not appear to be valid.<br />';
}
$string_exp = "/^[A-Za-z .'-]+$/";
if(!preg_match($string_exp,$first_name)) {
$error_message .= 'The First Name you entered does not appear to be valid.<br />';
}
if(!preg_match($string_exp,$last_name)) {
$error_message .= 'The Last Name you entered does not appear to be valid.<br />';
}
if(strlen($comments) < 2) {
$error_message .= 'The Comments you entered do not appear to be valid.<br />';
}
if(strlen($error_message) > 0) {
died($error_message);
}
$email_message = "Form details below.'n'n";
function clean_string($string) {
$bad = array("content-type","bcc:","to:","cc:","href");
return str_replace($bad,"",$string);
}
$email_message .= "Name: ".clean_string($first_name)."'n";
$email_message .= "Email: ".clean_string($email_from)."'n";
$email_message .= "Message: ".clean_string($comments)."'n";
// create email headers
$headers = 'From: '.$email_from."'r'n".
'Reply-To: '.$email_from."'r'n" .
'X-Mailer: PHP/' . phpversion();
mail($email_to, $email_subject, $email_message, $headers);
?>
<!-- include your own success html here -->
Thank you for contacting us. We will be in touch with you very soon.
<?php
}
?>
你的问题在这里:
if(z.value == "Your Message*"){
alert("Please write a message.");
return false;
e = e + 1
} else if(z.value == "Required Field"){
z.value = "Required Field"
e = e + 1
} return false;
由于您在右大括号之后有该return false;
,因此您的代码在到达该点时始终停止。
此外,在增加 e 后是否返回 false 并不一致;有时你返回 false,有时你不返回,当你这样做时,你在增加 e 之前返回 false,在这种情况下,e 实际上并没有改变。你应该总是在这里做同样的事情。
另外,在您的 html 中:
<input type="submit" onclick="myFunction()" class="submit" value="Submit" >
onclick
应该是return myFunction()
的,否则表单提交将始终发生,无论您的javascript函数的结果如何。
问题不在于你的PHP,而在于你的HTML和Javascript,因为页面没有重新加载:
.HTML:
我认为最好写:
<form onSubmit="MyFunction();" name="contact" action="sendform.php" method="post" >
因为当您像这样使用它时,它会减少写入MyFunction()
而不是在提交按钮的onClick
侦听器中return MyFunction()
JavaScript:
你写了var e
、var y
、var z
、var x
没有;
。
当您检查z.value == 'requiredfield'
是否在}
之前写入了返回 false 时。
e
永远不会递增,因为在递增之前,您return false;
是什么阻止了它递增。
如果您修复了这些错误并尝试了代码,则页面刷新并且电子邮件未送达,请在评论中回复,我将很乐意为您提供帮助。
编辑:
现在我知道这些修复后的问题提交按钮不是表单的一部分,因为您关闭表单然后添加提交,因此只需将提交按钮向上移动到</form>
之前
我认为这是因为它:
if(e > 0){
return false;
} else {
alert("Thank you. Your message has been sent!");
return true;
}
}
每次验证通过时,您将向 e 添加 1,它将始终大于 0,我不知道是否是您的错误,但我认为它应该是这样的
if(e != 5){
return false;
} else {
alert("Thank you. Your message has been sent!");
return true;
}
}
为什么是5?因为 u 将 1 加到 e 5 倍,所以最后它应该保持 5。
- php&js-将电子邮件添加到输入文本中
- 将用户制作的SVG(raphael.js)发送到服务器(php),以便通过电子邮件发送
- jSignature图像导出到PHP电子邮件
- 蛋糕PHP电子邮件 - 包括电子邮件中的链接
- 从 postmaster@domain.co.uk 收到的 PHP 电子邮件表单
- 使用AngularJs,尝试通过Google App Engine上的PHP使用HTML联系我们表单发送电子邮件
- 当用HTML5+JS+PHP设计发送到电子邮件的表单时,需要采取哪些良好的安全预防措施
- 有没有办法检测电子邮件地址的假域名?使用Perl、php、javascript
- PHP电子邮件联系表格
- 如何使用正则表达式根据javascript中的php电子邮件注入验证电子邮件地址
- 使用php将表单数据发送到电子邮件
- 用于电子邮件比较/验证的PHP代码
- 使用PHP和Javascript为每个用户电子邮件生成新的哈希
- 使用PHP,JQuery,Ajax将电子邮件添加到MySQL数据库中
- 从Mandril,Sendgrid或任何API PHP代码发送批量电子邮件
- 使用 PHP 和 Jquery 将表单输入字段添加到电子邮件中
- 如何通过 PHP 将多个复选框值发送到电子邮件
- 如何在PHP中从
中提取电子邮件 - HTML/PHP 电子邮件表单
- 简单的ajax调用数据库来验证电子邮件PHP编码器