您尝试使用 get 方法发送文件。 Get 方法不支持多部分。对于上传文件,您应该使用 post 方法,并且表单应该具有 multipart/form-data。你的表格应该像
<form method="post" action="" enctype="multipart/form-data" id="sendMailForm">
<input type="hidden" name="code" id="code" value="1234"/>
<input type="hidden" name="subject" id="subject" value="Hello My Friends"/>
<input type="submit" value="Send Mail" />
在表单提交中调用SendMail函数。
$("#sendMailForm").submit(function(evt){
evt.preventDefault();
var formData = new FormData($(this)[0]);
SendMail(formData);
return false;
});
function SendMail(formData){
$.ajax({
url: 'SendMail.php',
type: 'POST',
data: formData,
async: false,
cache: false,
contentType: false,
enctype: 'multipart/form-data',
processData: false,
success: function (response) {
alert(response);
}
});
}
在服务器端更新附加文件的发送邮件代码,并在 post 方法而不是 get 方法中获取数据。
require '../PHPMailer_5.2.4/PHPMailerAutoload.php';
$server = "localhost";
$user = "root";
$pass = "pass";
$bd = "BD";
$strHTML1=$_POST["cod"];
$strHTML2=$_POST["subject"];
$strHTML3= $strHTML1.$strHTML2;
$mail="[email protected]";
session_start();
$conexion = mysqli_connect($server, $user, $pass,$bd)
or die("ERROR");
$mail = new PHPMailer();
$mail->isSMTP();
$mail->CharSet = "UTF-8";
$mail->SMTPDebug = 2;
$mail->Mailer = "smtp";
$mail->WordWrap = 50;
$mail->PluginDir = "../tickets/PHPMailer_5.2.4/";
$mail->Debugoutput = 'html';
$mail->Host = 'smtp.gmail.com';
$mail->Port = 465;
$mail->SMTPSecure = 'ssl';
$mail->SMTPAuth = true;
$mail->Username = "[email protected]";
$mail->Password = "12345";
$mail->SMTPSecure = 'ssl';
$headers = "MIME-Version: 1.0\r\n";
$headers .= "Content-type: text/html; charset=iso-8859-1\r\n";
$headers .= "From:Home\r\n";
$mail->AddAddress($mail, "test");
$mail->isHTML(true);
$mail->Subject = $strHTML2;
$mail->Body =$strHTML3;
//Attach file in sendmail -
if (isset($_FILES['myFile']) &&
$_FILES['myFile']['error'] == UPLOAD_ERR_OK) {
$mail->AddAttachment($_FILES['myFile']['tmp_name'],
$_FILES['uploaded_file']['name']);
}
if(!$mail->send()) {
echo 'Message could not be sent.';
echo 'Mailer Error: ' . $mail->ErrorInfo.' ';
exit;
}
$close = mysqli_close($conexion)
or die("ERROR");