Inviare allegati decodificati

  • Creatore Discussione Creatore Discussione lamp
  • Data di inizio Data di inizio

lamp

Nuovo Utente
22 Giu 2014
1
0
0
Salve a tutti,
ho un piccolo problema con il codice, ho preso questo codice da questo sito, serve ad inviare un e-mail ed anche l'allegato.
Il problema e che quando allego un file me lo invia codificato, infatti vedo così: dhisfhuivnvufhguinbvbn.
Come posso fare in modo che venga ricevuto già decodificato?

PHP:
<?php 

// Recupero il valore dei campi del form 
$destinatario = $_POST['destinatario']; 
//$mittente = $_POST['mittente']; 
$funzione = $_POST['funzione']; 
$messaggio = $_POST['messaggio']; 
//$check = $_POST['check']; 

// Valorizzo le variabili relative all'allegato 
$allegato = $_FILES['allegato']['tmp_name']; 
$allegato_type = $_FILES['allegato']['type']; 
$allegato_name = $_FILES['allegato']['name']; 




			
	
	if (empty($_POST['mittente']))
			{
				die("Attenzione: Devi inserire l'email.<br>Torna <a href='lavora.php'>Indietro</a>.");
			}
			elseif (!empty($_POST['mittente']))
			{	
				$mittente = $_POST['mittente'];
				// Creo 2 variabili che riempirò più avanti... 
				$headers = "From: " . $mittente; 
				$msg = ""; 

	if (empty($_POST['check']))
				{
					die("Attenzione: Devi autorizzare il trattamento dei dati personali.<br>Torna <a href='lavora.php'>Indietro</a>.");
				}
				
	include_once 'securimage/securimage.php';
		
		$securimage = new Securimage();
	if ($securimage->check($_POST['captcha_code']) == false) 
		{
				echo "Attenzione: Il codice non &egrave corretto.<br /><br />";
				echo "Torna <a href='lavora.php'>Indietro</a>.";
				exit;	
		}  
		else
		{
// Verifico se il file è stato caricato correttamente via HTTP 
// In caso affermativo proseguo nel lavoro... 

if (is_uploaded_file($allegato)) 
{  
  // Apro e leggo il file allegato 
  $file = fopen($allegato,'rb'); 
  $data = fread($file, filesize($allegato)); 
  fclose($file);  
  
  // Adatto il file al formato MIME base64 usando base64_encode 
  //$data = chunk_split(base64_encode($data)); 

  // Genero il "separatore" 
  // Serve per dividere, appunto, le varie parti del messaggio. 
  // Nel nostro caso separerà la parte testuale dall'allegato 
  $semi_rand = md5(time()); 
  $mime_boundary = "==Multipart_Boundary_x{$semi_rand}x"; 
   
  // Aggiungo le intestazioni necessarie per l'allegato 
  $headers .= "\nMIME-Version: 1.0\n"; 
  $headers .= "Content-Type: multipart/mixed;\n"; 
  $headers .= " boundary=\"{$mime_boundary}\""; 

  // Definisco il tipo di messaggio (MIME/multi-part) 
  $msg .= "This is a multi-part message in MIME format.\n\n"; 

  // Metto il separatore 
  $msg .= "--{$mime_boundary}\n"; 

  // Questa è la parte "testuale" del messaggio 
  $msg .= "Content-Type: text/plain; charset=\"iso-8859-1\"\n"; 
  $msg .= "Content-Transfer-Encoding: 7bit\n\n"; 
  $msg .= $messaggio . "\n\n"; 

  // Metto il separatore 
  $msg .= "--{$mime_boundary}\n"; 

  // Aggiungo l'allegato al messaggio 
  $msg .= "Content-Disposition: attachment;\n"; 
  $msg .= " filename=\"{$allegato_name}\"\n"; 
  $msg .= "Content-Transfer-Encoding: base64\n\n"; 
  $msg .= $data . "\n\n"; 
  
  
  // chiudo con il separatore 
  $msg .= "--{$mime_boundary}--\n"; 
} 
else 
{ 
  $msg = $messaggio; 
} 

// Invio la mail 

$send = mail($destinatario, $funzione, $msg, $headers, $check); 
$msg2 .= base64_decode($data);
$send .= mail($send, $msg2);
if ($send) 
{ 
  echo "<p>Mail inviata con successo!</p>";
  echo "Torna <a href='lavora.php'>Indietro</a>.";
}else{ 
  echo "<p>Errore!</p>"; 
  echo "Torna <a href='lavora.php'>Indietro</a>.";
} 

		}		
			}
?>
 
Ultima modifica di un moderatore:
ciao
se non vado errato tu apri il file
$allegato = $_FILES['allegato']['tmp_name'];
dovresti aprire il file originale non il temporaneo
poi due cose
1) passa alla classe phpmailler e molto comoda per inviare gli allegati
https://www.mrw.it/php/inviare-email-classe-phpmailer_7047.html
2) quando si usano allegati è importante verificarne il tipo limitando l'invio a solo certi tipi (es. jpg e/o gif e/o png), corri il rischio che ti inviino qualche bel virus
 

Discussioni simili