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