Leggere la posta elettronica mediante le sole risorse di Gambas
Da Gambas-it.org - Wikipedia.
Per leggere mediante le risorse di Gambas la propria posta elettronica, è necessario attivare i seguenti Componenti:
- gb.net
- gb.net.pop3
- gb.mime
Mostriamo un esempio pratico, laddove:
- pop.host rappresenta il Server di posta elettronica dell'utente (ad esempio: pop.tiscali.it);
- pop.Port rappresenta la porta Porta POP3 con SSL del Server (ad esempio con Tiscali: 995);
- pop.User rappresenta l'identificativo della casella di posta elettronica dell'utente (esempio: identificativo@tiscali.it, ma anche più semplicemente: identificativo);
- pop.Password rappresenta la password dell'utente per accedere alla sua casella di posta elettronica.
Public Sub Main() Dim pop As New Pop3Client Dim mm As Mime Dim mimess As MimeMessage Dim nomefile, dati_allegato, idHeader As String Dim contenuto, decodifica As String Dim email, codifica As Integer With pop .Host = "pop.server.xx" .Port = numero_porta .User = "identificativo_utente" .Password = "password" .Encrypt = Net.SSL .Debug = False .Open() End With ' Imposta il numero d'indice (che ha inizio da zero) della e-mail ricevuta da leggere: email = 4 ' Controlla che il numero d'indice impostato corrisponda ad un e-mail esistente: If email > pop.Count - 1 Then Print "\n\e[5mIl numero di e-mail scelto è superiore a quello delle e-mail effettivamente presenti !" Quit Endif Print "===== E-MAIL RICEVUTA n. "; email + 1; " =====\n" With mimess = New MimeMessage(pop[email].Text) ' Mostra il mittente della e-mail ed il suo indirizzo: Print "\e[1mMittente: \e[21m "; .Sender Print "\e[1mTo: \e[21m "; .To If Not IsNull(.Cc) Then Print "\e[1mCc: \e[21m "; .Cc If Not IsNull(.BCc) Then Print "\e[1mBcc: \e[21m "; .BCc ' Mostra l'argomento della e-mail: Print "\e[1mArgomento: \e[21m "; .Subject Print "\n--------------------------------------" Print "\e[1mTESTO: \e[21m \n" ' Legge il testo della prima parte della e-mail: Print .Part[0].Data ' Verifica se c'è un file allegato. Se c'è, lo scarica: If .Part[.Part.Count - 1].ContentDisposition Like "*attachment*" Then Print "\n--------------------------------------" nomefile = .Part[.Part.Count - 1].FileName codifica = .Part[.Part.Count - 1].ContentEncoding idHeader = .Part[.Part.Count - 1].ContentId contenuto = .Part[.Part.Count - 1].ToString() dati_allegato = Scan(contenuto, "*" & idHeader & ">\n*")[1] decodifica = mm.Decode(dati_allegato, codifica) Print "\n\e[1mFile allegato: \e[21m "; nomefile ' Salva il file allegato con il nome e nel percorso prescelti: File.Save("/tmp" &/ nomefile, decodifica) Endif End With ' Effettua il logout da Server e si disconnette: pop.Close() End