因此,當從我的網站上註冊的商家訂購產品時,我希望我的程式碼能夠更新他們,同時將相同的電子郵件發送到我們公司的電子郵件地址。 當代碼發送到我們公司的電子郵件地址時,不會發送給商家的郵件。 你能告訴我哪裡可能是錯的嗎?謝謝。
請注意,電子郵件變數屬於商家,主要是 Gmail 帳號。這可能是 gmail 的限制還是什麼?
function mail_merchants_and_shoply($cart_code){ $conn = $this -> connection; $merchant_sent = false; $shoply_sent = false; $query = mysqli_query($conn, "SELECT * FROM business_account ORDER BY business_id DESC")or die(mysqli_error($conn)); while($row = mysqli_fetch_array($query)){ $id = $row['business_id']; $stat = "NEW"; $email = $row['email_add']; $name = $row['business_name']; $c_query = mysqli_query($conn, "SELECT * FROM cart_db WHERE business_id = '$id' AND cart_code = '".mysqli_real_escape_string($conn, $cart_code)."'")or die(mysqli_error($conn)); $merchant_mail_body = "<h2>NEW ORDER</h2><ul>"; while($arr = mysqli_fetch_array($c_query)){ $p_id = $arr['product_id']; $p_query = mysqli_query($conn, "SELECT * FROM products WHERE product_id = '$p_id'")or die(mysqli_error($conn)); $p_arr = mysqli_fetch_array($p_query); $image = $p_arr['product_image1_url']; $price = $p_arr['product_price']; $name = $p_arr['product_name']; $image = "<img src = 'https://www.shoply.ng/backend/$image' style = 'max-width: 200px; max-height: 200px'/>"; $merchant_mail_body.="<li>$name</li> <li>$image</li> <li> $price</li>"; } $merchant_mail_body .="</ul>"; $mail_subject = "NEW SHOPLY ORDER"; // $mailHead = implode("\r\n", ["MIME-Version:1.0","Content-type:text/html; charset =utf-8"]); $mailHead = "MIME-Version: 1.0" . "\r\n"; $mailHead .= "Content-type:text/html;charset=UTF-8" . "\r\n"; // Additional headers $mailHead .= 'From: Shoply<orders@shoply.ng>' . "\r\n"; if(mail($email, $mail_subject, $merchant_mail_body, $mailHead)){ $merchant_sent = true; } $s_query = mysqli_query($conn, "SELECT * FROM cart_db WHERE cart_code = '".mysqli_real_escape_string($conn, $cart_code)."'")or die(mysqli_error($conn)); $o_query = mysqli_query($conn, "SELECT * FROM orders WHERE order_code = '".mysqli_real_escape_string($conn, $cart_code)."'")or die(mysqli_error($conn)); $o_arr = mysqli_fetch_array($o_query); $location = $o_arr['delivery_location']; $phone = $o_arr['delivery_phone']; $user_fname = $_SESSION['user_fname']; $shoply_mail_body = "<h2>NEW ORDER</h2> FROM: $user_fname <ul> <li><b>Address:</b> $location</li> <li><b>Phone Number: </b>$phone</li>"; // $f_arr = mysqli_fetch_array($s_query); // $customer_id = $f_arr['customer_id']; // $c_query = mysqli_query($conn, "SELECT * FROM customers WHERE customer_id= '$customer_id'")or die(mysqli_error($conn)); // $c_arr[] while($row = mysqli_fetch_array($s_query)){ $p_id = $row['product_id']; $p_query = mysqli_query($conn, "SELECT * FROM products WHERE product_id = '$p_id'")or die(mysqli_error($conn)); $p_arr = mysqli_fetch_array($p_query); $image = $p_arr['product_image1_url']; $price = $p_arr['product_price']; $name = $p_arr['product_name']; $image = "<img src = 'https://www.shoply.ng/backend/$image' style = 'max-width: 200px; max-height: 200px'/>"; $shoply_mail_body.="<li>$name</li> <li>$image</li> <li> $price</li>"; } $shoply_mail_body .="</ul>"; $email = "sales@shoply.ng"; $mail_subject = "NEW SHOPLY ORDER"; // $mail_head = implode("\r\n", ["MIME-Version:1.0","Content-type:text/html; charset =utf-8"]); $headers = "MIME-Version: 1.0" . "\r\n"; $headers .= "Content-type:text/html;charset=UTF-8" . "\r\n"; // Additional headers $headers .= 'From: Shoply<orders@shoply.ng>' . "\r\n"; if(mail($email, $mail_subject, $shoply_mail_body, $headers)){ $shoply_sent = true; } if($merchant_sent && $shoply_sent){ return true; }else{ return false; } } }
我建議使用 php mailter 而不是內建的郵件功能。
PHP 的 mail() 函數使用伺服器的基本郵件伺服器,在共用主機上,這些伺服器通常具有糟糕的電子郵件聲譽,因此被許多收件者伺服器封鎖。 PHP Mailer 允許您直接與任何外部網路伺服器通信,如果您想發送電子郵件,甚至可以透過 Gmail 進行通信。
https://github.com/PHPMailer/PHPMailer