Silverlight è un plug-in per browser e come tale Microsoft mantiene volutamente molto elevato il contesto di sicurezza, per evitare che codice malizioso possa compromettere il sistema dell'utente. Per queste ed altre motivazioni, se vogliamo aggiungere una funzionalità di invio email alla nostra applicazione, dobbiamo appoggiarci ad un web service che si occupi di eseguire tale operazione.
Un servizio ASP.NET può utilizzare le classi SmtpClient e MailMessage del namespace System.Net.Mail, con le quali preparare il messaggio e comunicare con il server SMTP per procedere nell'invio. Oltre ai parametri di tipo stringa per destinatario, soggetto e messaggio, se vogliamo consentire all'utente di aggiungere un allegato possiamo predisporre il servizio per ricevere un array di byte. Vediamone una semplice implementazione:
[WebMethod] public void Send(string subject, string to, string message, byte[] attach) { MailMessage mailMessage = new MailMessage(); mailMessage.Subject = subject; mailMessage.SubjectEncoding = System.Text.Encoding.UTF8; mailMessage.BodyEncoding = System.Text.Encoding.UTF8; mailMessage.IsBodyHtml = true; SmtpClient smtpClient = new SmtpClient(); smtpClient.Host = "smtp.server.it"; smtpClient.UseDefaultCredentials = false; smtpClient.DeliveryMethod = SmtpDeliveryMethod.Network; smtpClient.Credentials = new NetworkCredential("local.invalid", "xxxxxx"); mailMessage.From = new MailAddress("local.invalid", string.Empty); mailMessage.To.Add(new MailAddress(to, string.Empty)); mailMessage.Body = string.Format("{0}", message); using (MemoryStream stream = new MemoryStream(attach)) { Attachment _attachment = new Attachment(stream, "allegato.jpg", MediaTypeNames.Application.Octet); mailMessage.Attachments.Add(_attachment); smtpClient.Send(mailMessage); } smtpClient.Dispose(); }
Il codice è semplice e autoesplicativo; per creare un oggetto Attachment corrispondente all'allegato possiamo creare uno stream con i byte inviati. Nell'esempio specifichiamo direttamente il nome dell'allegato per esteso, direttamente con l'estensione. Possiamo perfezionare il codice creando una logica autonoma di calcolo del Mime corrispondente.
Il WebMethod Send può essere esposto da un semplice webservice asmx, con cui possiamo interagire dal progetto Silverlight dopo aver creato un riferimento ed aver preparato la classe proxy.
Una chiamata al servizio potrebbe essere così definita:
Service.SendEmailServiceSoapClient service = new Service.SendEmailServiceSoapClient(); service.SendCompleted += new EventHandler<AsyncCompletedEventArgs>((obj, args) => { if (args.Error == null) { txbEsito.Text = "messaggio inviato correttamente"; } else { txbEsito.Text = String.Format("Si è verificato un errore {0}", args.Error); } }); service.SendAsync(txbSoggetto.Text, txbDestinatario.Text, txbMessaggio.Text, barray);
Come di consueto, in Silverlight usiamo il modello asincrono: al metodo SendAsync passiamo tutti i parametri che riteniamo utili per l'invio della email, e ci registriamo all'evento SendCompleted per gestirne l'esito.
Possiamo consentire all'utente di scegliere un file da allegare alla email attraverso la classe OpenFileDialog. Dopo aver scelto il file, in questo esempio una immagine jpg, apriamo il FileStream e andiamo a valorizzare l'array di byte che passeremo al servizio, così come nel codice seguente.
OpenFileDialog openFileDialog1 = new OpenFileDialog(); openFileDialog1.Filter = "Text Files (*.jpg)|*.jpg"; if (openFileDialog1.ShowDialog() == true) { using (FileStream reader = openFileDialog1.File.OpenRead()) { int len = (int)reader.Length; barray = new Byte[len]; reader.Read(barray, 0, len); } }
In allegato potete trovare il codice completo ed un semplice design che può essere una base di partenza per realizzare un "modulo di contatto".
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Ottenere il contenuto di una cartella FTP con la libreria FluentFTP
Utilizzare la libreria Benchmark.NET per misurare le performance
Ottimizzare la latenza in Blazor 8 tramite InteractiveAuto render mode
Implementare il throttling in ASP.NET Core
Usare una container image come runner di GitHub Actions
Eseguire attività con Azure Container Jobs
Come migrare da una form non tipizzata a una form tipizzata in Angular
Limitare le richieste lato server con l'interactive routing di Blazor 8
Sfruttare MQTT in cloud e in edge con Azure Event Grid
Gestire errori funzionali tramite exception in ASP.NET Core Web API
Generare file per il download da Blazor WebAssembly
Mascherare l'output di un valore all'interno dei log di un workflow di GitHub
I più letti di oggi
- I nuovi metodi degli array di ECMAScript 5
- Evitare (o ridurre) il repo-jacking sulle GitHub Actions
- Un custom control BoundField con dropdownlist
- .NET Core 3, C#8 and beyond
- Utilizzare long polling in HTML5 per richieste in real time
- Utilizzare le shortcut da tastiera con KeyboardAccelerator nella Universal Windows Platform
- Microsoft Security Bulletin MS05-048