[英]Create PDF file from html ajax form in php
我有一個簡單的聯系表格。 它通過AJAX發送電子郵件。 工作正常。
現在我需要從這個表單的結果創建PDF文件,並將其下載到這里的用戶
所以html形式:
<form id="contact-form">
<input type="hidden" name="action" value="contact_send" />
<input type="text" name="name" placeholder="Your name..." />
<input type="email" name="email" placeholder="Your email..." />
<textarea name="message" placeholder="Your message..."></textarea>
<input type="submit" value="Send Message" />
</form>
在functions.php我有發送電子郵件的功能:
function sendContactFormToSiteAdmin () {
try {
if (empty($_POST['name']) || empty($_POST['email']) || empty($_POST['message'])) {
throw new Exception('Bad form parameters. Check the markup to make sure you are naming the inputs correctly.');
}
if (!is_email($_POST['email'])) {
throw new Exception('Email address not formatted correctly.');
}
$subject = 'Contact Form: '.$reason.' - '.$_POST['name'];
$headers = 'From: My Blog Contact Form <contact@myblog.com>';
$send_to = "contact@myblog.com";
$subject = "MyBlog Contact Form ($reason): ".$_POST['name'];
$message = "Message from ".$_POST['name'].": \n\n ". $_POST['message'] . " \n\n Reply to: " . $_POST['email'];
if (wp_mail($send_to, $subject, $message, $headers)) {
echo json_encode(array('status' => 'success', 'message' => 'Contact message sent.'));
exit;
} else {
throw new Exception('Failed to send email. Check AJAX handler.');
}
} catch (Exception $e) {
echo json_encode(array('status' => 'error', 'message' => $e->getMessage()));
exit;
}
}
add_action("wp_ajax_contact_send", "sendContactFormToSiteAdmin");
add_action("wp_ajax_nopriv_contact_send", "sendContactFormToSiteAdmin");
所以在footer.php我有一個腳本ajax處理程序:
jQuery(document).ready(function ($) {
$('#contact-form').submit(function (e) {
e.preventDefault(); // Prevent the default form submit
var $this = $(this); // Cache this
$.ajax({
url: '<?php echo admin_url("admin-ajax.php") ?>', // Let WordPress figure this url out...
type: 'post',
dataType: 'JSON', // Set this so we don't need to decode the response...
data: $this.serialize(), // One-liner form data prep...
beforeSend: function () {},
error: handleFormError,
success: function (data) {
if (data.status === 'success') {
handleFormSuccess();
} else {
handleFormError(); // If we don't get the expected response, it's an error...
}
}
});
});
});
所有這一切都很棒。 但我不明白我在哪里粘貼代碼用於創建PDF,我試圖將其粘貼到sendContactFormToSiteAdmin
php函數中,但它沒有用。
在這個例子中,我需要在sendContactFormToSiteAdmin
php函數中准確地粘貼這段代碼:
ob_start();
?>
<h1>Data from form</h1>
<p>Name: <?php echo $name;?></p>
<p>Email: <?php echo $email;?></p>
<?php
$body = ob_get_clean();
$body = iconv("UTF-8","UTF-8//IGNORE",$body);
include("mpdf/mpdf.php");
$mpdf=new \mPDF('c','A4','','' , 0, 0, 0, 0, 0, 0);
$mpdf->WriteHTML($body);
$mpdf->Output('demo.pdf','D');
但我不明白如何使用ajax響應。
編輯為Shoaib Zafar評論說,如果可以通過電子郵件發送pdf文件作為電子郵件的附件,當然對我來說這是最好的。
要將PDF作為附件發送電子郵件,您需要更改電子郵件發送功能。
function sendContactFormToSiteAdmin () {
try {
if (empty($_POST['name']) || empty($_POST['email']) || empty($_POST['message'])) {
throw new Exception('Bad form parameters. Check the markup to make sure you are naming the inputs correctly.');
}
if (!is_email($_POST['email'])) {
throw new Exception('Email address not formatted correctly.');
}
ob_start();
?>
<h1>Data from form</h1>
<p>Name: <?php echo $_POST['name'];?></p>
<p>Email: <?php echo $_POST['email'];?></p>
<?php
$body = ob_get_clean();
// Supposing you have already included ("mpdf/mpdf.php");
$mpdf=new \mPDF('c','A4','','' , 0, 0, 0, 0, 0, 0);
$mpdf->WriteHTML($body);
$pdf_content = $mpdf->Output('', 'S');
$pdf_content = chunk_split(base64_encode($pdf_content));
$uid = md5(uniqid(time()));
$filename = 'contact.pdf';
$subject = 'Contact Form: '.$reason.' - '.$_POST['name'];
$message = "Message from ".$_POST['name'].": \n\n ". $_POST['message'] . " \n\n Reply to: " . $_POST['email'];
$header = 'From: My Blog Contact Form <contact@myblog.com>';
$header .= "--".$uid."\r\n";
$header .= "Content-type:text/plain; charset=iso-8859-1\r\n";
$header .= "Content-Transfer-Encoding: 7bit\r\n\r\n";
$header .= $message."\r\n\r\n";
$header .= "--".$uid."\r\n";
$header .= "Content-Type: multipart/mixed; boundary=\"".$uid."\"\r\n\r\n";
$header .= "Content-Type: application/pdf; name=\"".$filename."\"\r\n";
$header .= "Content-Transfer-Encoding: base64\r\n";
$header .= "Content-Disposition: attachment; filename=\"".$filename."\"\r\n\r\n";
$header .= $pdf_content."\r\n\r\n";
$header .= "--".$uid."--";
$send_to = "contact@myblog.com";
$subject = "MyBlog Contact Form ($reason): ".$_POST['name'];
if (wp_mail($send_to, $subject, $message, $header)) {
echo json_encode(array('status' => 'success', 'message' => 'Contact message sent.'));
exit;
} else {
throw new Exception('Failed to send email. Check AJAX handler.');
}
} catch (Exception $e) {
echo json_encode(array('status' => 'error', 'message' => $e->getMessage()));
exit;
}
}
我不太了解wp_email函數是如何工作的,但從技術上講這個代碼應該可以工作,你只需要重構它。 您也可以在官方文檔中找到它,以了解有關mPDF示例#3的更多信息
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.