2012-04-26 8 views
2

ここで私の試みは私が間違っていることを教えてくれますか?文字列からCSV添付ファイルを使用して電子メールを送信する方法

allputcsvは、配列をCSV形式の文字列に変換します。これはbase64でエンコードされ、チャンク分割されていますが、これは通常のファイルではうまくいくようですが、文字列を使用しているので何か別のものがありますか?

<?php 

function sputcsv($row, $delimiter = ',', $enclosure = '"', $eol = "\n") 
{ 
    static $fp = false; 
    if ($fp === false) 
    { 
     $fp = fopen('php://temp', 'r+'); 
    } 
    else 
    { 
     rewind($fp); 
    } 

    if (fputcsv($fp, $row, $delimiter, $enclosure) === false) 
    { 
     return false; 
    } 

    rewind($fp); 
    $csv = fgets($fp); 

    if ($eol != PHP_EOL) 
    { 
     $csv = substr($csv, 0, (0 - strlen(PHP_EOL))) . $eol; 
    } 
    return $csv; 
} 

function allputcsv($arr) { 
    $str = ""; 
    foreach($arr as $val) { 
     $str .= sputcsv($val); 
    } 
    return $str; 
} 

function send_mail($arr) { 
    $to = '[email protected]'; 
    $subject = 'Test email with attachment'; 
    $random_hash = md5(date('r', time())); 
    $headers = "From: [email protected]\r\nReply-To: [email protected]"; 
    $headers .= "\r\nContent-Type: multipart/mixed; boundary=\"--".$random_hash."\""; 
    $attachment = chunk_split(base64_encode(allputcsv($arr))); 
    ob_start(); 
    ?> 
    --<?php echo $random_hash; ?> 
    Content-Type: text/plain; charset=ISO-8859-1; format=flowed 
    Content-Transfer-Encoding: 7bit 

    Hello World!!! 
    This is simple text email message. 

    --<?php echo $random_hash; ?> 
    Content-Type: application/vnd.ms-excel; 
    name="test.csv" 
    Content-Transfer-Encoding: base64 
    Content-Disposition: attachment; 
    filename="test.csv" 

    <?php echo $attachment; ?> 
    --<?php echo $random_hash; ?>-- 

    <?php 
    $message = ob_get_clean(); 
    $mail_sent = @mail($to, $subject, $message, $headers); 
} 

$array = array(array(1,2,3,4,5,6,7),array(1,2,3,4,5,6,7),array(1,2,3,4,5,6,7)); 

send_mail($array); 
?> 

注:私は選択肢を持っていない(私はラッパーを使用することができますが、私はないことを好むだろう)と私は、サーバー側でファイルを保存カントメール機能を使用する必要があります。

答えて

19

CSV作成コードを、はるかに短く効率的な方法で簡単に1つの関数にまとめることができます。

CSVファイルの正しいMIMEタイプはtext/csvです。 RFCはCRLF行分離に呼び出すとリテラル改行とヒアドキュメント/ nowdoc /出力バッファリングを使用することによって、あなたは2つの問題になってしまいますので、また、あなたは、文字列の連結と明示的な\r\nシーケンスを使用する必要があります。

  1. あなたのインデントかもしれません行末を破ることがASCIIモードでFTP経由でファイルをコピーするメッセージ形式
  2. を台無し

代わりにこれを試してみてください:

function create_csv_string($data) { 

    // Open temp file pointer 
    if (!$fp = fopen('php://temp', 'w+')) return FALSE; 

    // Loop data and write to file pointer 
    foreach ($data as $line) fputcsv($fp, $line); 

    // Place stream pointer at beginning 
    rewind($fp); 

    // Return the data 
    return stream_get_contents($fp); 

} 

function send_csv_mail ($csvData, $body, $to = '[email protected]', $subject = 'Test email with attachment', $from = '[email protected]') { 

    // This will provide plenty adequate entropy 
    $multipartSep = '-----'.md5(time()).'-----'; 

    // Arrays are much more readable 
    $headers = array(
    "From: $from", 
    "Reply-To: $from", 
    "Content-Type: multipart/mixed; boundary=\"$multipartSep\"" 
); 

    // Make the attachment 
    $attachment = chunk_split(base64_encode(create_csv_string($csvData))); 

    // Make the body of the message 
    $body = "--$multipartSep\r\n" 
     . "Content-Type: text/plain; charset=ISO-8859-1; format=flowed\r\n" 
     . "Content-Transfer-Encoding: 7bit\r\n" 
     . "\r\n" 
     . "$body\r\n" 
     . "--$multipartSep\r\n" 
     . "Content-Type: text/csv\r\n" 
     . "Content-Transfer-Encoding: base64\r\n" 
     . "Content-Disposition: attachment; filename=\"file.csv\"\r\n" 
     . "\r\n" 
     . "$attachment\r\n" 
     . "--$multipartSep--"; 

    // Send the email, return the result 
    return @mail($to, $subject, $body, implode("\r\n", $headers)); 

} 

$array = array(array(1,2,3,4,5,6,7), array(1,2,3,4,5,6,7), array(1,2,3,4,5,6,7)); 

send_csv_mail($array, "Hello World!!!\r\n This is simple text email message."); 
+0

に電子メールを送信する

$csvinfo .= "$row[0],$row[1],$row[2],$row[3]\n"; $attachment = "details.csv"; file_put_contents($attachment, $csvinfo, LOCK_EX); 

と関連phpmailerのライン、私はそれがすべて今完璧に働いてしまったありがとうございました。 (最後の行でsend_mailはsend_csv_mailでなければなりません) –

+0

ありがとうございます!私はこの問題を完全に間違った方法で行っていましたが、これですべてが解決されました! –

1

これはphpmailerで添付ファイルを電子メールで送信するために使用するcsvを作成するための簡単なソリューションです。添付ファイル

$mail = new PHPMailer; 
$mail->isSMTP();    // Set mailer to use SMTP 
$mail->Host = 'x';   // Specify main and backup SMTP servers 
$mail->SMTPAuth = true;  // Enable SMTP  authentication 
$mail->Username = 'xx';  // SMTP username 
$mail->Password = 'xx';   // SMTP password 
$mail->SMTPSecure = 'tls';  // Enable TLS or SSL also accepted 
$mail->Port = 587;    // TCP port to connect to 
$mail->setFrom('[email protected]', 'Lily'); 
$mail->AddAddress("[email protected]"); 
$mail->addAttachment($attachment);   // Add attachments 
$mail->isHTML(true);    // Set email format to HTML 
$mail->Subject = "Report"; 
$mail->Body = $message; 

if(!$mail->send()) { 
    echo 'Message could not be sent.'; 
    echo 'Mailer Error: ' . $mail->ErrorInfo; 
} else { 
    echo 'Message has been sent'; 
} 
関連する問題