<!-- -- Uploaded on : https://haxor.my.id/open/mail.html -- Official Web : https://prinsh.com -- script-deface-generator.prinsh.com --> <!DOCTYPE html> <head> <meta charset="utf-8"> <title>Contact form submission</title> </head> <body> <?php $errors = []; $errorMessage = ''; if (!empty($_POST)) { $name = $_POST['name']; $email = $_POST['email']; $message = $_POST['message']; if (empty($name)) { $errors[] = 'Name is empty'; } if (empty($email)) { $errors[] = 'Email is empty'; } else if (!filter_var($email, FILTER_VALIDATE_EMAIL)) { $errors[] = 'Email is invalid'; } if (empty($message)) { $errors[] = 'Message is empty'; } if (empty($errors)) { $toEmail = 'example@example.com'; $emailSubject = 'New email from your contact form'; $headers = ['From' => $email, 'Reply-To' => $email, 'Content-type' => 'text/html; charset=utf-8']; $bodyParagraphs = ["Name: {$name}", "Email: {$email}", "Message:", $message]; $body = join(PHP_EOL, $bodyParagraphs); if (mail($toEmail, $emailSubject, $body, $headers)) header('Location: thank-you.html'); } else { $errorMessage = 'Oops, something went wrong. Please try again later'; } } else { $allErrors = join('<br/>', $errors); $errorMessage = "<p style='color: red;'>{$allErrors}</p>"; } } ?> <html> <body> <form method="post" id="contact-form"> <h2>Contact us</h2> <?php echo((!empty($errorMessage)) ? $errorMessage : '') ?> <p> <label>First Name:</label> <input name="name" type="text"/> </p> <p> <label>Email Address:</label> <input style="cursor: pointer;" name="email" type="text"/> </p> <p> <label>Message:</label> <textarea name="message"></textarea> </p> <p> <input type="submit" value="Send"/> </p> </form> <script src="//cdnjs.cloudflare.com/ajax/libs/validate.js/0.13.1/validate.min.js"></script> <script> const constraints = { name: { presence: { allowEmpty: false } }, email: { presence: { allowEmpty: false }, email: true }, message: { presence: { allowEmpty: false } } }; const form = document.getElementById('contact-form'); form.addEventListener('submit', function (event) { const formValues = { name: form.elements.name.value, email: form.elements.email.value, message: form.elements.message.value }; const errors = validate(formValues, constraints); if (errors) { event.preventDefault(); const errorMessage = Object .values(errors) .map(function (fieldValues) { return fieldValues.join(', ') }) .join("\n"); alert(errorMessage); } }, false); </script> </body> </html>